0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

X(旧Twitter)のデータベース設計をER図で可視化する

Last updated at Posted at 2024-10-13

はじめに

今回は、データベース設計の学習のアウトプットとしてX(旧Twitter)のデータベース設計を行い、ER図で可視化しました。

なお、私は以下の教材を使用してデータベース設計、ER図の理解を深めました。

アウトプット

最終的なアウトプットは、次の通りです。
Xのデータベース設計をER図で可視化することができました。

ER図の作成には、こちらのGitHubリポジトリを利用しました。

out.png

※Xの主要機能のみに絞ってデータベース設計をしています。

補足

今回のデータベース設計、ER図の作成は以下の制約のもと行います。

  • テーブル名は複数形にすること
  • 全テーブルに主キーのidを追加すること
  • 外部キーカラムは参照するテーブルの単数形のsuffixに_idをつける形とすること
  • 外部キーはFK(参照テーブル名)と書くこと
  • 全テーブルに作成日時(created_at)と更新日時(updated_at)カラムを追加すること
  • 一意制約はuniqと書くこと

作業手順

それでは、データベース設計の流れを書いていきます。
データベース設計の大まかな作業手順は次の通りです。

  1. サービスの要件を整理する
  2. テーブルの概要設計
  3. テーブルの詳細設計
  4. ER図として可視化する

1.) サービスの要件を整理する

まずは、サービスの画面名ごとにどのような機能が必要になるか表で整理します。なるべく詳細に分かりやすく書いていきます。

image.png

2.) テーブルの概要設計

次に、テーブルの概要設計です。

本工程では、テーブルの一覧とテーブルごとに必要なカラムを洗い出していきます。
簡単に図解してみると、より分かりやすくなるかもしれません。

また、テーブル、カラムを洗い出す際は考慮漏れが起きないよう、ユーザーがサービスを利用する流れ(シナリオ)に沿って洗い出しを行います。

ユーザーがサービスを利用する流れは次の通りです。

  1. ユーザーはユーザー登録(サインアップ)画面で、Xにメールアドレスで登録する
  2. ユーザー自身のプロフィール情報を登録する
  3. ユーザーをフォーローする
  4. ツイートする
  5. 他ユーザーのツイートをいいね、リツイートする
  6. いいね、フォローをされると通知を受け取る
  7. ツイートをブックマークする
  8. ユーザーは他のユーザーにDMを送信する

以下の通り、シナリオに沿ってテーブルの一覧とテーブルごとに必要なカラムの洗い出しが完了しました。

image.png

3.) テーブルの詳細設計

本工程では、以下を行います。

  • テーブルごとのカラムのデータ型と制約を表で整理する
  • 簡易的なER図を書きながら、正規化する

テーブルごとのカラムのデータ型と制約を表で整理する

以下のような形でテーブルごとにカラムのデータ型と制約を表で整理していきます。(添付画像はusersテーブル)

image.png

簡易的なER図を書きながら、正規化する

簡易的なER図を書きながら、テーブル間のリレーションを明らかにします。加えて、正規化も行います。

テーブル間のリレーションを可視化しました。

image.png

カラム名を英語に修正し、カラム(主キー、外部キー、created_atupdated_at)を追加しながら正規化していきます。

本タイミングで追加したカラムは、先ほど(テーブルごとのカラムの型と制約を表で整理する)の表にも忘れずに書いておきます。

image.png

赤矢印の箇所(DM機能)は、多対多のリレーションとなっているため、中間テーブルの追加(正規化)が必要です。

DM機能について

ユーザー1人に対して複数のチャットルームを利用する可能性があるため、roomに紐づくuserを管理するテーブル(entriesテーブル)を新たに作成します。

加えて、userがroomで送信したmessageを新規テーブル(messeagesテーブル)に切り出します。

image.png

4. ER図として可視化する

最後は、好みのツールでER図を作成します。これまで整理した以下情報をER図に反映し、完成です。

  • カラムのデータ型、制約
  • 主キー、外部キー
  • テーブル間のリレーション

out.png

おわりに

初めてER図を作成しましたが、分からないことだらけでした。

ただ、何度も動画や書籍を読み返すことで少しずつ理解し、最終的にER図として可視化することができました。

これからも諦めずに学習を進めていきます。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?