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

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

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

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

PHP

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

Q&A

解決済

1回答

3540閲覧

Laravel リレーションがうまくいかない?

eroeronnnnnn

総合スコア10

Laravel

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

PHP

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

0グッド

0クリップ

投稿2020/05/17 08:32

前提・実現したいこと

Laravel 6系を使用しています。
今回、問い合わせ画面を作成するにあたり、「都道府県」のセレクトボックスを作成することになりました。
セレクトボックスの中身(「北海道」など)はDBに保存しています。
そこで、問い合わせテーブル「contacts」に「pref_id」という外部キーを設けて、都道府県テーブル「prefectures」とリレーションを持たせようとしているのですが、問い合わせ情報を取得するときに都道府県の内容が取得できないくて困っています

該当のソースコード

「都道府県」のマスタテーブルを作成するマイグレーションファイル

php:

1<?php 2 3use Illuminate\Database\Migrations\Migration; 4use Illuminate\Database\Schema\Blueprint; 5use Illuminate\Support\Facades\Schema; 6 7class CreatePrefecturesTable extends Migration 8{ 9 /** 10 * Run the migrations. 11 * 12 * @return void 13 */ 14 public function up() 15 { 16 Schema::create('prefectures', function (Blueprint $table) { 17 $table->increments('id'); 18 $table->integer('code')->default(0); 19 $table->text('name'); 20 }); 21 } 22 23 /** 24 * Reverse the migrations. 25 * 26 * @return void 27 */ 28 public function down() 29 { 30 Schema::dropIfExists('prefectures'); 31 } 32}

「問い合わせ」のテーブルを作成するマイグレーションファイル

php:

1<?php 2 3use Illuminate\Database\Migrations\Migration; 4use Illuminate\Database\Schema\Blueprint; 5use Illuminate\Support\Facades\Schema; 6 7class CreateContactsTable extends Migration 8{ 9 /** 10 * Run the migrations. 11 * 12 * @return void 13 */ 14 public function up() 15 { 16 Schema::create('contacts', function (Blueprint $table) { 17 $table->increments('id'); 18 $table->timestamps(); 19 $table->string('first_name'); 20 $table->string('last_name'); 21 $table->string('email'); 22 $table->string('job_title'); 23 $table->string('city'); 24 $table->string('country'); 25 $table->unsignedInteger('pref_id'); 26 $table->foreign('pref_id')->references('id')->on('prefectures'); 27 }); 28 } 29 30 /** 31 * Reverse the migrations. 32 * 33 * @return void 34 */ 35 public function down() 36 { 37 Schema::dropIfExists('contacts'); 38 } 39}

試したこと

「お問い合わせ」のモデルにbelongsToを定義しました。

php:

1<?php 2 3namespace App\Models; 4use Illuminate\Database\Eloquent\Model; 5 6class Contact extends Model 7{ 8 protected $fillable = [ 9 'first_name', 'last_name', 'email', 'city', 'country', 'job_title', 'pref_id', 10 ]; 11 public function prefecture(){ 12 return $this->belongsTo('App\Models\Prefecture'); 13 } 14} 15

問い合わせのコントローラで全件データを取得しました。

php:

1class ContactController extends Controller 2{ 3 /** 4 * Display a listing of the resource. 5 * 6 * @return \Illuminate\Http\Response 7 */ 8 public function index() 9 { 10 $contacts = Contact::all(); 11 var_dump($contacts); 12 return view('contacts.index', compact('contacts')); 13 }

上記のように。var_dumpで全件確認してみたのですが、「お問い合わせ」のモデルでbelongsToした情報が取れないです。
データも登録されているのですが、リレーションの使い方に誤りがあるのでしょうか?

ご回答お願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Contactモデルのリレーション定義方法に誤りがありますよ。

Laravelのドキュメントには以下の記載があります。
https://readouble.com/laravel/6.x/ja/eloquent-relationships.html#one-to-many

Eloquentはリレーションメソッドの名前として、_に続けて主キーのカラム名をサフィックスとして付けた名前をデフォルトの外部キーとします。 しかしCommentモデルの外部キーがpost_idでなければ、belongsToメソッドの第2引数にカスタムキー名を指定してください。

多分こんな感じだと取得できそうです。

php

1public function prefecture(){ 2 return $this->belongsTo('App\Models\Prefecture', 'pref_id'); 3}

Laravelのドキュメントは落ち着いて読めば簡単なことしか書いていないので、ハマったら確認しにいくのがよいですよ!

投稿2020/05/17 11:38

hhiroki

総合スコア39

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

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

eroeronnnnnn

2020/05/19 06:36

ありがとうございます!ドキュメントしっかり読みます。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問