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

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

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

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

Q&A

解決済

1回答

4155閲覧

Laravelでリレーション先が取得できない

tktail

総合スコア72

Laravel

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

0グッド

0クリップ

投稿2021/11/29 03:38

ケアレスミスと思いますが、質問させて下さい。
UsersとUserRoleという2つのテーブルがあり、Usersを読み込んだ時に一緒にUserRoleも取得したいと考えています。

モデルは以下のように作成しました。

User.php

1namespace App\Models; 2use Illuminate\Database\Eloquent\Model; 3use Illuminate\Foundation\Auth\User as Authenticatable; 4use Auth; 5 6class User extends Authenticatable{ 7 public function user_role(){ 8 return $this->belongsTo('App\Models\UserRole', 'role_id', 'id'); 9 } 10} 11

UserRole.php

1 2<?php 3namespace App\Models; 4use Illuminate\Database\Eloquent\Model; 5 6class UserRole extends Model 7{ 8 protected $table = 'user_role'; 9} 10

リレーションが上手く行っているかどうか確かめるため、tinkerを使い、以下のようにコマンドを入力しましたが、期待する結果は得られませんでした。

>>> App\Models\User::where('id', '81')->user_role->get(); Exception with message 'Property [user_role] does not exist on the Eloquent builder instance.'

リレーションはuser側にrole_idが存在しているので、user側からデータを取得する場合はbelongsToではないかなとの認識です。
tinkerはコマンドが間違っているかもしれません。

ご指摘よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

idがPrimary Keyなら

App\Models\User::find(81)->user_role();

とかならいけそうな気もします。whereの後に直接やってもダメかと。基本的に->user_role()はUserモデルのインスタンスにしか使えないはずです。find()の場合はUserモデルがそのまま帰ってくるので使えると思います。

find()を使わずにget()を使う場合はCollectionのインスタンスが帰ってくるはずなので、そのままでは使えないはずです。

App\Models\User::with('user_role')->where('id', '81')->get();

として、返ってくるCollectionの中に入ってるそれぞれのUserモデルのインスタンスから->user_role()が使えると思います。

投稿2021/11/29 04:20

編集2021/11/29 04:34
AbeTakashi

総合スコア4594

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

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

tktail

2021/11/29 04:37

ご回答ありがとうございます。 頂いたコマンドで確認したら、リレーション出来ていることが確認できました。 with('name')というのを先につけてあげないといけないのですね・・・勉強します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問