コンテンツにスキップ

テーブル設計

テーブル名は英語ならば複数形/複数名詞で書ける。そうでなければそのテーブルにはどこか間違いがある。

主キー

必ず1行のレコードを特定できる列の組み合わせのことを指す。

テーブルに必ず1つだけ存在する必要がある。

複合キー

複数列を組み合わせて主キーになるものを複合キーという。

外部キー

別のテーブルの主キーになっているキー。

外部キーが設定されている場合、不整合が起こりうるのでデータの削除は子から順に操作するべき。

キーについて

キーとなる列にはコードやIDなど表記体系の定まった固定長の文字列を用いる。

正規化

データベースで保持するデータの冗長性をなくすこと。第1正規形から第5正規形まである。通常は第3正規形までを考える。

第1正規形

1つのセルの中に1つの値しか含まない状態。

配列はNG。列を増やすか、別途テーブルを切る。

第2正規形

部分関数従属をなくす。部分関数従属とは主キーの一部の列に対して従属する(一部の列が主キーの値によって決まっている)こと。

部分関数従属をなくすにはテーブルを分割する。

正規化は結合によって非正規形(分割前のテーブルの形式)に戻すことができる。

第3正規形

推移的関数従属をなくす。主キー以外の列に対して従属すること。詳細は達人に学ぶDB設計 徹底指南書の3-6を参照。