Laravel5にてWebアプリ開発の学習をしております。
まず、現状を説明します。
多対多の関係にある2つのテーブルとその中間テーブルを作成しました。
[Movieテーブル] (映画)
id,title
1 ,タイタニック
2 ,アバター
[Personテーブル] (人物)
id,name
1 ,ジェームズ・キャメロン
2 ,レオナルド・デカプリオ
[movie_personテーブル] (中間テーブル)
movie_id,person_id
1 ,1
1 ,2
lang
1//movie.php 2class Movie extends Model { 3 public function people() { 4 return $this->belongsToMany('App\person')->withTimestamps(); 5 } 6}
lang
1//movie.blade.php 2<div> 3 <h2>{{ $movie->title }}</h2> 4 <h5>company:</h5> 5 <ul> 6 @foreach($movie->people as $person) 7 <li>{{ $person->name }}</li> 8 @endforeach 9 </ul> 10</div>
この状態で映画のタイトルから人物情報の取得はできています。
ここからさらに、監督、脚本、出演の情報を追加するために、中間テーブルにカラムを追加しました。
[Movieテーブル] (映画)
id,name
1 ,タイタニック
2 ,アバター
[Personテーブル] (人物)
id,name(UNIQUE)
1 ,ジェームズ・キャメロン
2 ,レオナルド・デカプリオ
[movie_personテーブル] (中間テーブル)
movie_id,person_id,role
1 ,1 ,監督
1 ,2 ,出演
この際、中間テーブルに新たに追加したroleカラムにはどのようにアクセスのでしょうか?
取得したい結果は
タイタニック 監督:ジェームズ・キャメロン 出演:レオナルド・デカプリオ
さらに追加で、以下のようなテーブル構造にした場合も教えていただきたいです
よろしくお願いいたします。
[Movieテーブル] (映画)
id, name
1 , タイタニック
2 , アバター
[Personテーブル] (人物)
id, name(UNIQUE)
1 , ジェームズ・キャメロン
2 , レオナルド・デカプリオ
[roleテーブル] (役割)
id, role
1 , director
2 , scriptwriter
3 , cast
[movie_personテーブル] (中間テーブル)
movie_id, person_id, role
1 , 1 , 1
1 , 2 , 3
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/05/24 18:58