データベースの作成
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/df5ff/df5ff516ffdb9f3ad157bde90356d5f5a4719efc" alt="コマンドプロンプト"
作成したデータベース「twitter」の中で作業するようにします。
ターミナルで以下を実行します。
use twitter;
data:image/s3,"s3://crabby-images/c035a/c035abc560b7f2f0f6d9768f257ead0a201d36b5" 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/2d4ee/2d4ee7e7f7bc8c496155a2d54099563d39df25df" 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/e2074/e2074e27141ccd42d9424a6c74756e37f1145638" 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/e8b33/e8b3338d2a45257ca32e7440748df09984dfedd8" 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/66e01/66e0130829936415aacf48732eabb0e6245344eb" 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/5e2c1/5e2c14e990464557008e139a327003d7aab20211" alt="コマンドプロンプト"
ここまでできたら、コマンドプロンプトで以下を実行し、正常に各テーブルが作成されていることを確認します。
show tables;
data:image/s3,"s3://crabby-images/d7045/d70456f6b9d03574a7988b2473bdca3b694be58a" alt="コマンドプロンプト"
本節の説明は以上になります。