多対多 (データモデル)
表示
システム解析では、多対多 (英: many-to-many) の関係は、2つの実体[1] AとBの間の関係を指すカーディナリティの一種であり、AにはBに多くの子が存在する親インスタンスが含まれる場合があり、その逆も同様である。
たとえば、Aを著者、Bを本と考えてみよう。著者は複数の本を書き、本は複数の著者によって書かれる。
リレーショナルデータベース管理システムでは、このような関係は通常、連想テーブル(もしくは結合テーブル、ジャンクションテーブル、相互参照テーブル)の方法で実装される。つまり、たとえば AB は2つの1対多の関係A→ ABとB→ ABを通して実装される。この場合、ABの論理主キーは、2つの外部キー(つまり、AとBの主キーのコピー)から形成される。
CakePHPやRuby on RailsなどのWebアプリケーションフレームワークでは、論理モデルデータベーステーブルによって表されるエンティティタイプ間の多対多の関係は、HasAndBelongsToMany(HABTM)リレーションシップと呼ばれることがある[2]。
関連項目
[編集]脚注
[編集]- ^ 実体関連モデルを参照すること。
- ^ 3.7.6.5 hasAndBelongsToMany (HABTM) Archived 2012-08-15 at the Wayback Machine.. Cakephp.org