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

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

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

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

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Laravel 5

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

Q&A

解決済

2回答

563閲覧

laravel5.7でeloquentでリレーションを使ってbladeに値を描画したい

yoshipu

総合スコア115

PHP

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

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Laravel 5

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

0グッド

0クリップ

投稿2019/02/09 13:53

編集2019/02/09 15:51

前提・実現したいこと

laravel5.7でeloquentでリレーションを使ってbladeに値を描画したい

試したのソースコード

php

1テーブルの情報 2 3mysql> select * from book_keeps; 4+----+--------------+------------+----------+-----------------+ 5| id | posting_date | subject_id | title_id | Amount_of_money | 6+----+--------------+------------+----------+-----------------+ 7| 1 | 2019/02/01 | 1 | 1 | 300000 | 8| 2 | 2019/02/01 | 1 | 2 | 80000 | 9| 3 | 2019/01/01 | 2 | 1 | 3000 | 10| 4 | 2019/02/01 | 2 | 3 | 108 | 11| 5 | 2019/02/01 | 2 | 4 | 5000 | 12+----+--------------+------------+----------+-----------------+ 135 rows in set (0.00 sec) 14 15mysql> select * from subjects; 16+----+---------+ 17| id | subject | 18+----+---------+ 19| 1 | 収益 | 20| 2 | 費用 | 21+----+---------+ 222 rows in set (0.00 sec) 23 24やりたいこと 25book_keepsテーブルのsubject_idを外部キーとしてsubjectsテーブルのsubjectをリレーションしてとってきたいです。参考サイトを参考にfind(1)しているのですが本当はall()で全レコードとりたいのですが、それを使うと取れませんでした。 26 27app/Http/Controllers/BookKeepController.php 28<?php 29 30namespace App\Http\Controllers; 31 32use App\Models\BookKeep; 33use App\Models\Subject; 34 35class BookKeepController extends Controller 36{ 37 public function index () 38 { 39 $book_keeps = BookKeep::find(1)->subjects; 40 return view('book_keep.index', ['book_keeps' => $book_keeps]); 41 } 42} 43 44app/Models/BookKeep.php 45 46<?php 47 48namespace App\Models; 49 50use Illuminate\Database\Eloquent\Model; 51 52class BookKeep extends Model 53{ 54 public $timestamps = false; 55 56 public function subjects () 57 { 58 return $this->belongsTo('App\Models\Subject', 'id'); 59 } 60} 61 62resources/views/book_keep/index.blade.php 63 64@foreach($book_keeps as $book_keep) 65 {{$book_keep->id}} 66 {{$book_keep->posting_date}} 67 {{$book_keep->subject}} 68 {{$book_keep->title_id}} 69 {{$book_keep->Amount_of_money}} 70 <br> 71@endforeach 72 73望む結果 74 751 2019/02/01 収益 1 300000 761 2019/02/01 収益 2 80000 772 2019/01/01 費用 1 3000 782 2019/02/01 費用 3 108 792 2019/02/01 費用 4 5000 80

補足情報(FW/ツールのバージョンなど)

php7.3
laravel5.7
mysql8.0

参考サイト
Laravel 5.7 Eloquent:リレーション
https://readouble.com/laravel/5.7/ja/eloquent-relationships.html#one-to-many

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

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

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

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

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

guest

回答2

0

ベストアンサー

$book_keeps = BookKeep::find(1)->subjects;

この行が間違ってますね。
BookKeep のリストを期待してますが、実際には Subject のリストが入ってしまいます。

kawax さんのおっしゃるとおり、hasOne/hasMany と belongsTo はややこしいですよね。

DBテーブル側で考えると、 hoge_id を持っているテーブルを子テーブルとします(上の場合は subject_id を持っている BookKeep が子)、

親: Subject
子: BookKeep

Subject has BookKeep

-> Subject クラスに BookKeep を返す hasOne/hasMany メソッドを置く

BookKeep belongs to Subject

-> BookKeep クラスに Subject を返す belongsTo メソッドを書く

という関係になるかと思います。

その上で、Subject がひとつの BookKeep しか持たないのであれば、

Subject has one BookKeep

になりますし、複数持つのであれば

Subject has many BookKeep

になります(今回のケースはこっちですね)

メソッド名は、 hasOne であれば単数形、hasMany であれば複数形、というようにすると混乱しなくていいと思います。

一方、belongsTo では自身の持つ hoge_id (この場合は subject_id )を常に参照するので、単数形になります。

なので、上の例だと、 BookKeep::subject(): BelongsTo の方がいいのではないかと思います。

最後に、belongsTo の第二引数についてですが、ここには hoge_idhoge の部分が、親テーブルの名前の単数形と一致してない場合にのみ使用します。

ちょっと文章で説明するのが難しいので式で書きます。

親テーブル名 = subjects
子テーブルのキー = book_keeps.subject_id

とした場合、(子テーブルのキー の _id を取り除いた部分) = (親テーブル名 の 単数形) = subject

となるので、この場合は不要です。

必要なケースは、

親テーブル名 = master_subjects
子テーブルのキー = book_keeps.subject_id

で一致しないので、以下のように第二引数を指定してやる必要があります。

php

1return $this->belongsTo(MasterSubject::class, 'subject_id');

投稿2019/02/10 03:20

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

yoshipu

2019/02/10 03:47

詳細にご回答いただきまして、ありがとうございます。 nunulkさんの解説を読みながらノートに図を書いたり、コードを編集して必ず、自分のものにしたいと思います。
guest

0

この場合は親子の認識が逆。
一つのSubjectが複数のBookKeepを持つ。
親の外部キーsubject_id持ってるほうが子。

ドキュメントと合わせると
Post=Subject
Comment=BookKeep

SubjectがhasMany
BookKeepがbelongsTo

第2引数以降は不要。

この辺りはややこしいので毎回ドキュメント見て親子のどっち側かを考えるしかない。

投稿2019/02/09 14:44

kawax

総合スコア10377

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

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

yoshipu

2019/02/09 15:52

ご回答ありがとうございます。 hasManyをbelongsToに変更し、引数も変えてみましたが、book_keepsのレコードの全部を取得できませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問