Type something to search...
How to Create a AWS RDS MySQL Database and Connect to it using MySQL Workbench

How to Create a AWS RDS MySQL Database and Connect to it using MySQL Workbench

Introduction

RDS is a managed service that makes it easy to set up, operate, and scale a relational database in the cloud. It provides cost-efficient and resizable capacity while automating time-consuming administration tasks such as hardware provisioning, database setup, patching and backups. It frees you to focus on your applications so you can give them the fast performance, high availability, security, and compatibility they need.

Prerequisites

  • AWS Account
  • MySQL Workbench

Create a AWS RDS MySQL Database

  1. Login to your AWS Console.

AWS Console

  1. Click on Services and then click on RDS.

RDS

  1. Click on Create Database.

Create Database

  1. Select MySQL as the database engine.

Select MySQL

  1. Select the MySQL version.

Select MySQL Version

  1. Select the template.

Select Template

  1. DB instance identifier.

DB Instance Identifier

  1. Master username and password.

Master Username and Password

  1. DB instance class.

DB Instance Class

  1. Storage.

Storage

  1. Public access

Public Access

  1. VPC security group.

VPC Security Group

  1. Additional configuration.

Additional Configuration

  1. Click on Create database.

Connect to the AWS RDS MySQL Database

  1. Get the endpoint of the database.

Get Endpoint

  1. Open MySQL Workbench.

Open MySQL Workbench

  1. Click on the + icon to add a new connection.

Add New Connection

  1. Enter the connection details.
    • Connection Name: Enter a name for the connection.
    • Hostname: Enter the endpoint of the database.
    • Username: Enter the username of the database.
    • Password: Enter the password of the database.

Enter Connection Details

  1. Click on Test Connection to test the connection.

  2. Click on OK to save the connection.

  3. Click on the connection to connect to the database.

You have successfully connected to the AWS RDS MySQL database.

Exercise 1: Create a Table

Create a 3 tables in the database, the tables are:

  • SAILORS - Contains the details of the sailors.
    • SID - The ID of the sailor.
    • SName - The name of the sailor.
    • SRating - The rating of the sailor.
    • SAge - The age of the sailor.
  • BOATS - Contains the details of the boats.
    • BID - The ID of the boat.
    • BName - The name of the boat.
    • BColor - The color of the boat.
  • RESERVES - Contains the details of the reservations.
    • SID - The ID of the sailor.
    • BID - The ID of the boat.
    • Day - The day of the reservation.
Click to expand the SQL solution.

Create the SAILORS table

CREATE TABLE `SAI`.`SAILORS` (
SID int auto_increment primary key,
SName varchar(30) not null,
SRating int default 0 check (SRating >= 0 and SRating <= 10),
SAge real default 18 check (SAge >= 18 and SAge <= 70)
);

Explanation:

Click to expand the explanation.
  • SID - The ID of the sailor.
  • SName - The name of the sailor.
  • SRating - The rating of the sailor.
  • SAge - The age of the sailor.
  • auto_increment - The ID will be automatically incremented.
  • primary key - The ID is the primary key of the table.
  • not null - The name of the sailor cannot be null.
  • default 0 - The rating of the sailor will be 0 by default.
  • check (SRating >= 0 and SRating <= 10) - The rating of the sailor must be between 0 and 10.
  • default 18 - The age of the sailor will be 18 by default.
  • check (SAge >= 18 and SAge <= 70) - The age of the sailor must be between 18 and 70.

Create the BOATS table

CREATE TABLE `SAI`.`BOATS` (
BID int auto_increment primary key,
BName varchar(30) not null,
BColor varchar(30) not null
);

Explanation:

Click to expand the explanation.
  • BID - The ID of the boat.
  • BName - The name of the boat.
  • BColor - The color of the boat.
  • auto_increment - The ID will be automatically incremented.
  • primary key - The ID is the primary key of the table.
  • not null - The name of the boat cannot be null.

Create the RESERVES table

CREATE TABLE `SAI`.`RESERVES` (
SID int not null,
BID int not null,
Day date not null,
primary key (SID, BID, Day),
);
alter table `SAI`.`RESERVES` add constraint `RESERVES_SAILORS_FK` foreign key (SID) references `SAI`.`SAILORS` (SID);
alter table `SAI`.`RESERVES` add constraint `RESERVES_BOATS_FK` foreign key (BID) references `SAI`.`BOATS` (BID);

Explanation:

Click to expand the explanation.
  • SID - The ID of the sailor.
  • BID - The ID of the boat.
  • Day - The day of the reservation.
  • primary key (SID, BID, Day) - The combination of the ID of the sailor, the ID of the boat and the day is the primary key of the table.
  • not null - The ID of the sailor, the ID of the boat and the day cannot be null.
  • alter table - Add a foreign key to the table.
  • RESERVES_SAILORS_FK - The name of the foreign key.
  • foreign key (SID) - The ID of the sailor is the foreign key.
  • references - References the SAILORS table.
  • RESERVES_BOATS_FK - The name of the foreign key.
  • foreign key (BID) - The ID of the boat is the foreign key.
  • references - References the BOATS table.

Insert data into the tables

Click to expand the SQL solution.
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (22, 'Dustin', 7, 45);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (29, 'Brutus', 1, 33);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (31, 'Lubber', 8, 55.5);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (32, 'Andy', 8, 25);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (58, 'Rusty', 10, 35);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (64, 'Horatio', 7, 35);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (71, 'Zorba', 10, 18);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (74, 'Horatio', 9, 40);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (85, 'Art', 3, 25.5);
insert into `SAI`.`SAILORS` (SID, SName, SRating, SAge) values (88, 'Bob', 3, 63.5);
insert into `SAI`.`BOATS` (BID, BName, BColor) values (101, 'Interlake', 'blue');
insert into `SAI`.`BOATS` (BID, BName, BColor) values (102, 'Interlake', 'red');
insert into `SAI`.`BOATS` (BID, BName, BColor) values (103, 'Clipper', 'green');
insert into `SAI`.`BOATS` (BID, BName, BColor) values (104, 'Marine', 'red');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (22, 101, '1998-10-10');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (22, 102, '1998-10-10');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (22, 103, '1998-10-8');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (22, 104, '1998-10-7');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (31, 102, '1998-11-10');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (31, 103, '1998-11-6');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (31, 104, '1998-11-12');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (64, 101, '1998-9-5');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (64, 102, '1998-9-8');
insert into `SAI`.`RESERVES` (SID, BID, Day) values (64, 103, '1998-9-8');

Exercise 2: Write a Querys

  • Find all information of sailors who have reserved boat number 101.
  • Find the names of sailors who have reserved a red boat, and list in the order of age.
  • Find the names of sailors who have reserved at least one boat.
  • Find the ids and names of sailors who have reserved two different boats on the same day.
  • Find the ids of sailors who have reserved a red boat or a green boat
Click to expand the SQL solution.
select * from `SAI`.`SAILORS`
where SID in (
select SID from `SAI`.`RESERVES`
where BID = 101
);

Explanation:

Click to expand the explanation.
  • select * - Select all columns.
  • from - From the SAILORS table.
  • where - Where the ID of the sailor is in the list of IDs of sailors who have reserved boat number 101.
  • SID in - The ID of the sailor is in the list.
  • select SID - Select the ID of the sailor.
  • from - From the RESERVES table.
  • where - Where the ID of the boat is 101.
select SName from `SAI`.`SAILORS`
WHERE SID in (
select SID from `SAI`.`RESERVES`
WHERE BID in (
select BID from `SAI`.`BOATS`
WHERE BColor = 'red'
)
)
order by SAge;

Explanation:

Click to expand the explanation.
  • select SName - Select the name of the sailor.
  • from - From the SAILORS table.
  • where - Where the ID of the sailor is in the list of IDs of sailors who have reserved a red boat.
  • SID in - The ID of the sailor is in the list.
  • select SID - Select the ID of the sailor.
  • from - From the RESERVES table.
  • where - Where the ID of the boat is in the list of IDs of red boats.
  • BID in - The ID of the boat is in the list.
  • select BID - Select the ID of the boat.
  • from - From the BOATS table.
  • where - Where the color of the boat is red.
  • order by - Order by the age of the sailor.
select SName from `SAI`.`SAILORS`
where SID in (
select SID from `SAI`.`RESERVES`
);

Explanation:

Click to expand the explanation.
  • select SName - Select the name of the sailor.
  • from - From the SAILORS table.
  • where - Where the ID of the sailor is in the list of IDs of sailors who have reserved a boat.
  • SID in - The ID of the sailor is in the list.
  • select SID - Select the ID of the sailor.
  • from - From the RESERVES table.
select SID from `SAI`.`SAILORS`
where SID in (
select SID from `SAI`.`RESERVES`
group by SID, Day
having count(*) = 2
);

Explanation:

Click to expand the explanation.
  • select SID - Select the ID of the sailor.
  • from - From the SAILORS table.
  • where - Where the ID of the sailor is in the list of IDs of sailors who have reserved two boats on the same day.
  • SID in - The ID of the sailor is in the list.
  • select SID - Select the ID of the sailor.
  • from - From the RESERVES table.
  • group by - Group by the ID of the sailor and the day.
  • having - Having the count of the number of boats reserved is 2.
select SID from `SAI`.`SAILORS`
where SID in (
select SID from `SAI`.`RESERVES`
where BID in (
select BID from `SAI`.`BOATS`
where BColor = 'red'
)
)
or SID in (
select SID from `SAI`.`RESERVES`
where BID in (
select BID from `SAI`.`BOATS`
where BColor = 'green'
)
);

Explanation:

Click to expand the explanation.
  • select SID - Select the ID of the sailor.
  • from - From the SAILORS table.
  • where - Where the ID of the sailor is in the list of IDs of sailors who have reserved a red boat or a green boat.
  • SID in - The ID of the sailor is in the list.
  • select SID - Select the ID of the sailor.
  • from - From the RESERVES table.
  • where - Where the ID of the boat is in the list of IDs of red boats or green boats.
  • BID in - The ID of the boat is in the list.
  • select BID - Select the ID of the boat.
  • from - From the BOATS table.
  • where - Where the color of the boat is red or green.

Conclusion

In this tutorial, you learned how to create a RDS instance, how to connect to it, and how to create a database and tables. You also learned how to insert data into the tables and how to write queries to retrieve data from the tables. You can use these skills to create a database for your own projects.

References

Related Posts

Check out some of our other posts

How To Create A Custom VPC Using AWS CLI

How To Create A Custom VPC Using AWS CLI

Introduction In the sample that follows, an IPv4 CIDR block, a public subnet, and a private subnet are all created using AWS CLI instructions. You can run an instance in the public subnet and conn

read more
How to Install and Setup FireWall on Amazon Linux 2

How to Install and Setup FireWall on Amazon Linux 2

Introduction We will learn how to install and setup FireWall on Amazon Linux 2 in this tutorial. We will also discover how to set up FireWall so that it functions with the Amazon Linux 2. Prer

read more
How to Install Apache Web Server on Amazon Linux 2

How to Install Apache Web Server on Amazon Linux 2

Introduction In this tutorial, we will learn how to install Apache web server on Amazon Linux 2. We will also learn how to configure Apache web server to run simple HTML web page. Prerequisite

read more
How to Install and Configure Node.js on EC2 Instance Amazon Linux 2

How to Install and Configure Node.js on EC2 Instance Amazon Linux 2

Introduction Node.js does not exist in the default Amazon Linux 2 repository. So, we need to add the Node.js repository to the system. In this post, we will learn how to install and configure Node

read more
How to Install PHP and MariaDB on Amazon Linux 2

How to Install PHP and MariaDB on Amazon Linux 2

Introduction We will learn how to set up PHP and MariaDB on Amazon Linux 2 in this tutorial. We will also discover how to set up PHP so that it functions with the Apache web server. We will also d

read more
How to Install WordPress on Amazon Linux 2

How to Install WordPress on Amazon Linux 2

Introduction We will learn how to install WordPress on Amazon Linux 2 in this tutorial. We will also discover how to set up WordPress so that it functions with the Apache web server. We will also

read more