データベースの作成
Twitter用のデータベースを作成します。
下図のように、「twitter」という名前のデータベースを作成し、その中に「ユーザー(users)」「フォロー(follows)」「通知(notifications)」「ツイート(tweets)」「いいね(likes)」の各テーブルを作成します。
data:image/s3,"s3://crabby-images/2a6cd/2a6cd362740897ff96545f0e435e101260f466f4" alt="データベース"
テーブル間の線および「1」「多」は、テーブル間の関係になります。
例えば、ユーザー1人に対して、複数のツイートを投稿できますよね。そのためユーザー(users)側が「1」、ツイート(tweets)側が「多」という関係になります。
ターミナルで以下を実行します。
create database twitter;
data:image/s3,"s3://crabby-images/e6c34/e6c34ec9db253da013db560b274066964c11a7ae" alt="ターミナル"
作成したデータベース「twitter」の中で作業するようにします。
ターミナルで以下を実行します。
use twitter;
data:image/s3,"s3://crabby-images/b2ada/b2ada0b28acf30338f7dfb13d75b6127ce655d02" alt="ターミナル"
テーブルの作成
データベース「Twitter」内にテーブルを作成します。
ユーザー(users)
ターミナルで以下のSQLを実行します。
create table users
(
id int not null auto_increment primary key,
status varchar(50) not null default ‘active’,
nickname varchar(50) not null,
name varchar(50) not null,
email varchar(254) not null,
password varchar(128) not null,
image_name varchar(1024) default null,
created_at datetime not null default current_timestamp,
updated_at datetime not null default current_timestamp
);
data:image/s3,"s3://crabby-images/8e152/8e152ade3dc862dc78a2991b3dadf6f7d2d24c2c" alt="ターミナル"
「current_timestamp」は文字通り「現在日時」という意味です。これを指定すると、データを追加するとき、MySQLが自動的に現在日時を登録してくれます。
ツイート(tweets)
ターミナルで以下のSQLを実行します。
create table tweets
(
id int not null auto_increment primary key,
status varchar(50) not null default ‘active’,
user_id int not null,
body varchar(140) not null,
image_name varchar(1024) default null,
created_at datetime not null default current_timestamp,
updated_at datetime not null default current_timestamp
);
data:image/s3,"s3://crabby-images/acb5b/acb5b0d515b2c16ae63647fa1748b2993a3b32ce" alt="ターミナル"
いいね(likes)
ターミナルで以下のSQLを実行します。
create table likes
(
id int not null auto_increment primary key,
status varchar(50) not null default ‘active’,
user_id int not null,
tweet_id int not null,
created_at datetime not null default current_timestamp,
updated_at datetime not null default current_timestamp
);
data:image/s3,"s3://crabby-images/25ac5/25ac5b504ea31c31c34710c7da30937e8deffd9c" alt="ターミナル"
フォロー(follows)
ターミナルで以下のSQLを実行します。
create table follows
(
id int not null auto_increment primary key,
status varchar(50) not null default ‘active’,
follow_user_id int not null,
followed_user_id int not null,
created_at datetime not null default current_timestamp,
updated_at datetime not null default current_timestamp
);
data:image/s3,"s3://crabby-images/4c612/4c61271adb648edf9dbeae34b21e2089a86b2e64" alt="ターミナル"
通知(notifications)
ターミナルで以下のSQLを実行します。
create table notifications
(
id int not null auto_increment primary key,
status varchar(50) not null default ‘active’,
sent_user_id int not null,
received_user_id int not null,
message varchar(50) not null,
created_at datetime not null default current_timestamp,
updated_at datetime not null default current_timestamp
);
data:image/s3,"s3://crabby-images/cddfa/cddfa42881007645e7df5cff4efe83fca6134a06" alt="ターミナル"
ここまでできたら、ターミナルで以下を実行し、正常に各テーブルが作成されていることを確認します。
show tables;
data:image/s3,"s3://crabby-images/d981b/d981b8c7c710709077ca077ded52373fdc8d28f3" alt="ターミナル"
本節の説明は以上になります。