質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

2回答

6684閲覧

Laravel5 中間テーブルに追加したカラムへのアクセス

actine

総合スコア16

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

3クリップ

投稿2015/04/30 08:16

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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

動かせるリポジトリを作成しています。良かったらどうぞ。

teratail-9252

投稿2015/05/22 11:14

localdisk

総合スコア84

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

actine

2015/05/24 18:58

ご丁寧にありがとうございます。 参考にさせていただきます!!
guest

0

ベストアンサー

withPivot を使いましょう。

lang

1<?php namespace App; 2 3use Illuminate\Database\Eloquent\Model; 4 5class Movie extends Model { 6 7 public function people() 8 { 9 return $this->belongsToMany(Person::class)->withPivot('role'); 10 } 11 12} 13

で View はこんなかんじです。

lang

1<!DOCTYPE HTML> 2<html lang="ja-JP"> 3 <head> 4 <title>Movie</title> 5 <meta charset="UTF-8"> 6 <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css"> 7 </head> 8 <body> 9 <div class="container"> 10 <div class="page-header"> 11 <h1>Movie</h1> 12 </div> 13 <div> 14 <h2>{{ $movie->title }}</h2> 15 <h5>company:</h5> 16 <ul> 17 @foreach($movie->people as $person) 18 <li>{{$person->pivot->role}} : {{ $person->name }}</li> 19 @endforeach 20 </ul> 21 </div> 22 </div> 23 </body> 24</html>

![結果]WIDTH:600

投稿2015/05/22 11:08

localdisk

総合スコア84

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

actine

2015/05/23 06:05

ありがとうございます。 withPivotをつかうのですね。 これでテーブルの操作の幅がひろがります。
actine

2015/05/24 18:57

モデルの中で belongsToMany(Person::class)と書かれているのですが belongsToMany('App\person')との違いはなんなのでしょうか。 コメント欄で失礼ですが、よろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問