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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Eloquent

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

Q&A

解決済

1回答

747閲覧

Eloquentのリレーションを使ってデータを取得したい

T.Takeda

総合スコア29

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Eloquent

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

0グッド

0クリップ

投稿2020/08/12 01:44

前提・実現したいこと

Eloquentのリレーションを使ってデータを取得したいのですのが、うまく取れずにいます。

projectsテーブル

+----+--------------+-----------------------+------------+-------+---------------------+---------------------+---------------------+ | id | organizer_id | place | min_member | level | open_at | created_at | updated_at | +----+--------------+-----------------------+------------+-------+---------------------+---------------------+---------------------+ | 1 | 1 | 体育館 | 2 | 1 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | | 2 | 2 | 小学校 | 6 | 2 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | | 3 | 3 | 消防署 | 4 | 3 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | +----+--------------+-----------------------+------------+-------+---------------------+---------------------+---------------------+

membersテーブル

| id | project_id | user_id | created_at | updated_at | +----+------------+---------+---------------------+---------------------+ | 1 | 1 | 1 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | | 2 | 2 | 1 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 | | 3 | 3 | 2 | 2020-08-11 07:07:44 | 2020-08-11 07:07:44 |

上記2テーブルからmembersテーブルでuser_id=1となっているproject_idの詳細情報をprojectsテーブルから抽出したいです。
この場合、user_id=1となっているproject_idは1と2なので、体育館と小学校のレコードが対象となります。

試したこと

MemberモデルでbelongsToを使ってみました。

php

1<?php 2 3namespace App; 4 5use Illuminate\Database\Eloquent\Model; 6 7class Member extends Model 8{ 9 public function projects() 10 { 11 return $this->belongsTo('App\Project', 'project_id'); 12 } 13}

tinkerで動くには動くのですが、そもそもfind()でmembersテーブルのidを指定しなくてはならないので、理想と異なります。

App\Member::find(1)->projects; => App\Project {#3865 id: 1, organizer_id: 1, place: "体育館", min_member: 2, level: 1, open_at: "2020-08-11 07:07:44", created_at: "2020-08-11 07:07:44", updated_at: "2020-08-11 07:07:44", }

イメージ的にはApp\Member::where('user_id', 1)->get()->projects;の様にwhereuser_idで条件をつけてからprojectテーブルの情報を結合したいのですが、こちらをtinkerで試すとエラーになりました。

なお、取得したデータはforeachで一つずつ取り出してビューに一覧で表示したいと考えております。

アドバイスの程、よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

※検証してないので、動くか不明ですが。

イメージ的にはApp\Member::where('user_id', 1)->get()->projects;の様にwhereでuser_idで条件をつけてからprojectテーブルの情報を結合したいのですが、こちらをtinkerで試すとエラーになりました。

エラー内容を見ると分かるかもしれませんが、get()で取得されるのはCollectionクラスなのでforeachで回してその上でprojectsを取得すればいけるかと思います。

$members = App\Member::where('user_id', 1)->get(); foreach ($members as $member) { echo $member->projects; }

Laravel 7.x Eloquent:コレクション
【Laravel】DB登録値取得時のfind()、get()、first()の返り値早見表

投稿2020/08/12 06:02

meshi_s

総合スコア276

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

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

T.Takeda

2020/08/22 22:59

ご回答ありがとうございます。また、遅くなってしまい、申し訳ございません。 ベストアンサーにさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問