🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Laravel

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

PHP

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

Q&A

解決済

1回答

810閲覧

Laravel:withによるEagerローディングと、whereによる検索を組み合わせ、Userとリレーションを持つ、特定のBoard情報を取り出せる様にしたい

Reikirin

総合スコア23

Laravel

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

PHP

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

0グッド

0クリップ

投稿2021/03/05 12:35

掌田津耶乃氏著の"PHPフレームワークLaravel入門"の本を参考に、Laravelで、webアプリを作っています。

LaravelのversionとしてはLaravel Framework 8.27.0を使っています。

Userとしてログインし、情報を入力して、それをBoardに保存して、検索によって、そのBoardの情報を取り出すことができる様なアプリを作ろうとしております。
UserとBoardの情報が結びついていることがわかる様に、withによるEagerローディングを使って、検索結果のBoardの情報の隣にUserのnameを表示できる様にはできました。

このUser情報と結びついた、特定のBoardを、/helloにおいて、whereを用いた条件付き検索で取り出せる様にしたいのですが、上手くいきません。

Models↓

User

1<?php 2 3namespace App\Models; 4 5use Illuminate\Contracts\Auth\MustVerifyEmail; 6use Illuminate\Database\Eloquent\Factories\HasFactory; 7use Illuminate\Foundation\Auth\User as Authenticatable; 8use Illuminate\Notifications\Notifiable; 9 10class User extends Authenticatable 11{ 12 use HasFactory, Notifiable; 13 14 /** 15 * The attributes that are mass assignable. 16 * 17 * @var array 18 */ 19 protected $fillable = [ 20 'name', 'email', 'password', 21 ]; 22 23 /** 24 * The attributes that should be hidden for arrays. 25 * 26 * @var array 27 */ 28 protected $hidden = [ 29 'password', 'remember_token', 30 ]; 31 32 /** 33 * The attributes that should be cast to native types. 34 * 35 * @var array 36 */ 37 protected $casts = [ 38 'email_verified_at' => 'datetime', 39 ]; 40 41 protected $guarded = array('id'); 42 43 public function boards() 44 { 45 return $this->hasMany('App\Models\Board'); 46 } 47}

Board

1<?php 2 3namespace App\Models; 4 5use Illuminate\Database\Eloquent\Factories\HasFactory; 6use Illuminate\Database\Eloquent\Model; 7 8class Board extends Model 9{ 10 protected $guarded = array('id'); 11 12 public static $rules = array( 13 'info_1' => 'required', 14 'info_2' => 'required', 15 'info_3' => 'required', 16 'info_4' => 'required', 17//理由があってinfo_5はrequiredではありません。 18 ); 19 20 public function user() 21 { 22 return $this->belongsTo('App\Models\User'); 23 } 24 25 public function getData() 26 { 27 return $this->info_1 . $this->info_2 . $this->info_3 . $this->info_4 . $this->info_5; 28 } 29}

View↓
(hello側のindex.blade.phpの@section('content')ディレクティブ(検索用))

index

1@if(isset($items)) 2 @section('content') 3 <div class="container"> 4 <table> 5 <tr><th>Circle_Information</th><th>User</th></tr> 6 @foreach ($items as $item) 7 <tr> 8 <td>{{$item->getData()}}</td> 9 <td>{{$item->user->name}}</td> 10 </tr> 11 @endforeach 12 </table> 13 </div> 14 @endsection 15@else 16 @section('content') 17 <div class="container"> 18 <form action="/hello" method="post"> 19 {{ csrf_field() }} 20 <div class="forms"> 21 <label class="form-tag"> 22 <input type="text" name="info_1"> 23 </label> 24 <label class="form-tag"> 25 <input type="text" name="info_2"> 26 </label> 27 <label class="form-tag"> 28 <input type="text" name="info_3"> 29 </label> 30 <label class="form-tag"> 31 <input type="text" name="info_4"> 32 </label> 33 <label class="form-tag"> 34 <input type="date" name="info_5"> 35 </label> 36 <label class="form-tag"> 37 <input type="submit" value="検索する"> 38 </label> 39 </div> 40 </form> 41 </div> 42 @endsection 43@endif

(board側のindex.blade.phpの@section('content')ディレクティブ(表示用))

index

1@section('content') 2<div class="container"> 3 <table> 4 <tr><th>Information</th><th>User</th></tr> 5 @foreach ($items as $item) 6 <tr> 7 <td>{{$item->getData()}}</td> 8 <td>{{$item->user->name}}</td> 9 </tr> 10 @endforeach 11 </table> 12</div> 13@endsection

(board側のadd.blade.phpの@section('content')ディレクティブ(入力用))

add

1@section('content') 2<div class="container"> 3 <table> 4 <form action="/board/add" method="post"> 5 {{ csrf_field() }} 6 <div class="a_form"> 7 <label>info_1 : </label> 8 <input type="text" name="info_1"> 9 </div> 10 <div class="a_form"> 11 <label>info_2 : </label> 12 <input type="text" name="info_2"> 13 </div> 14 <div class="a_form"> 15 <label>info_3 : </label> 16 <input type="text" name="info_3"> 17 </div> 18 <div class="a_form"> 19 <label>info_4 : </label> 20 <input type="text" name="info_4"> 21 </div> 22 <div class="a_form"> 23 <label>info_5 : </label> 24 <input type="text" name="info_5"> 25 </div> 26 <div class="a_form"> 27 <input type="submit" value="送信する"> 28 </div> 29 </form> 30 </table> 31</div> 32@endsection

Controller↓

HelloController

1class HelloController extends Controller 2{ 3 4 public function index(Request $request) 5 { 6 $user = Auth::user(); 7 $param = ['user' => $user]; 8 return view('hello/index', $param); 9 } 10 11 public function post(Request $request) 12 { 13 $user = Auth::user(); 14 $items = Board::with('user')->where('info_1', '%' . $request->info_1 . '%') 15 ->where('info_2', '%' . $request->info_2 . '%') 16 ->where('info_3', '%' . $request->info_3 . '%') 17 ->where('info_4', '%' . $request->info_4 . '%') 18 ->where('info_5', '%' . $request->info_5 . '%') 19 ->get(); 20 $param = [ 21 'info_1' => $request->info_1, 22 'info_2' => $request->info_2, 23 'info_3' => $request->info_3, 24 'info_4' => $request->info_4, 25 'info_5' => $request->info_5, 26 'user' => $user, 27 'items' => $items, 28 ]; 29 return view('hello/index', $param); 30 } 31}

BoardController

1<?php 2 3namespace App\Http\Controllers; 4 5use App\Models\Board; 6use Illuminate\Http\Request; 7use Illuminate\Support\Facades\Auth; 8 9class BoardController extends Controller 10{ 11 public function index(Request $request) 12 { 13 $user = Auth::user(); 14 $items = Board::with('user')->get(); 15 $param = [ 16 'user' => $user, 17 'items' => $items, 18 ]; 19 return view('board/index', $param); 20 } 21 22 public function add(Request $request) 23 { 24 $user = Auth::user(); 25 $param = ['user' => $user]; 26 return view('board/add', $param); 27 } 28 29 public function create(Request $request) 30 { 31 $this->validate($request, Board::$rules); 32 $board = new Board; 33 $board->user_id = Auth::id(); 34 $form = $request->all(); 35 unset($form['_token']); 36 $board->fill($form)->save(); 37 return redirect('/board'); 38 } 39}

routes > web.php↓

web

1<?php 2 3use Illuminate\Support\Facades\Route; 4use App\Http\Middleware\HelloMiddleware; 5 6 7Route::get('/', function () { 8 return view('welcome'); 9}); 10 11Route::get('hello', 'App\Http\Controllers\HelloController@index'); 12Route::post('hello', 'App\Http\Controllers\HelloController@post'); 13 14Route::get('board', 'App\Http\Controllers\BoardController@index'); 15 16Route::get('board/add', 'App\Http\Controllers\BoardController@add'); 17Route::post('board/add', 'App\Http\Controllers\BoardController@create');

/helloで検索しても欲しい情報が出てこないのはどうしてなのでしょうか?
/boardに直接アクセスすると入力した全てのテーブルは表示されるのですが。。。

どなたかわかる方がいらっしゃれば、ご教授お願い致します。

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

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

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

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

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

phper.k

2021/03/05 12:48

検索条件が AND 検索だからでは? OR 検索(orWhere)にすべきところじゃないですか?
Reikirin

2021/03/05 13:05

$items = Board::with('user')->orWhere('info_1', '%' . $request->info_1 . '%') ->orWhere('info_2', '%' . $request->info_2 . '%') ->orWhere('info_3', '%' . $request->info_3 . '%') ->orWhere('info_4', '%' . $request->info_4 . '%') ->orWhere('info_5', '%' . $request->info_5 . '%') ->get(); の形でしょうか?それとも $items = Board::with('user')->Where('info_1', '%' . $request->info_1 . '%') ->orWhere('info_2', '%' . $request->info_2 . '%') ->orWhere('info_3', '%' . $request->info_3 . '%') ->orWhere('info_4', '%' . $request->info_4 . '%') ->orWhere('info_5', '%' . $request->info_5 . '%') ->get(); の形が正しいでしょうか? 一応どちらも試しましたが、検索はできませんでした、、、
phper.k

2021/03/05 13:20

どっちも同じSQL実行する。
phper.k

2021/03/05 13:21

「検索できない」のか、「検索の結果が表示されない」のかわかった上で、「検索されない」と言っていますか?
Reikirin

2021/03/05 13:25

>どっちも同じSQL実行する。 ー承知しました。 >「検索できない」のか、「検索の結果が表示されない」のかわかった上で、「検索されない」と言っていますか? ー語弊がある言い方ですみません、「検索の結果が表示されない」です。
phper.k

2021/03/05 13:29

きつい言い方に聞こえるかもしれないのですが、ちょっとデバッグ作業が足りないように見受けられます。検索ワードをPOSTしたときに、index() メソッド実行されてる?
Reikirin

2021/03/05 13:47

検索ワードをPOSTした時にindex() メソッド実行されてるかは、実行されていると思います、、、 hello側のindex.blade.phpの@if(isset($items)) @elseの場合分けが起こって検索フォームが消えるので。 デバッグ作業についてですがおっしゃる通りかもしれません。経験が浅い初心者ですので、そのデバッグ作業に慣れていないです。数日悩んだ上で質問しているので、質問丸投げみたいなつもりは一切ないのですが。
phper.k

2021/03/05 13:54

責めているわけじゃないので、勘違いしないで欲しい。 > 検索ワードをPOSTした時にindex() メソッド実行されてるかは、実行されていると思います、、、 熟練したプログラマでも、「〜と思う」と言う段階では、絶対にバグ潰せません。 実行されているかを確認してください。 確実に実行されているかを、確認し、よし、ここはOK!と言うように事実を積み重ねるんです。 「〜と思う」と言う推測が正しいかを検証しましょう
Reikirin

2021/03/05 13:59

無知で申し訳ありませんが検索ワードをPOSTした時にindex() メソッド実行されてるかを確実に確かめる方法は具体的にどんなものがあるでしょうか?
phper.k

2021/03/05 14:15 編集

例えば、 public function post(Request $request) { dd($request); // こんな感じで、ここの関数が実行されるかを確認できますよね。 $user = Auth::user(); inde() じゃなくて、post() でしたね、検索のコード書いてるの。
Reikirin

2021/03/05 15:22

ありがとうございます。ご指摘いただいた通り、実行したところ Illuminate\Http\Request {#43 ▼ #json: null #convertedFiles: null #userResolver: Closure($guard = null) {#1206 ▶} #routeResolver: Closure() {#1216 ▶} +attributes: Symfony\Component\HttpFoundation\ParameterBag {#45 ▶} +request: Symfony\Component\HttpFoundation\ParameterBag {#44 ▶} +query: Symfony\Component\HttpFoundation\InputBag {#51 ▶} +server: Symfony\Component\HttpFoundation\ServerBag {#47 ▶} +files: Symfony\Component\HttpFoundation\FileBag {#48 ▶} +cookies: Symfony\Component\HttpFoundation\InputBag {#46 ▶} +headers: Symfony\Component\HttpFoundation\HeaderBag {#49 ▶} #content: null #languages: null #charsets: null #encodings: null #acceptableContentTypes: null #pathInfo: "/hello" #requestUri: "/hello" #baseUrl: "" #basePath: null #method: "POST" #format: null #session: Illuminate\Session\Store {#1247 ▶} #locale: null #defaultLocale: "en" -preferredFormat: null -isHostValid: true -isForwardedValid: true -isSafeContentPreferred: null basePath: "" format: "html" } が返ってきたのですが、これはpost()メソッドが実行されていないということでしょうか?
phper.k

2021/03/05 15:33

帰ってきたのであれば通っていると言うことですね。
Reikirin

2021/03/05 15:45

post()が通っていることがわかったところで、あと他に何か考えられる原因はありますでしょうか? もし何か思い当たるものがございましたらご教授していただきたいです。
phper.k

2021/03/05 15:49

それを探るのがデバッグなんで、本来はあなたがやるべき。 デバッグ方法が身に付けば、自力でコード書けるようになる。 自力でデバッグできるようになるための手伝いならいくらでもする。 答えを教えるだけでは、その場の満足で終わってしまう。 まずは推測するー>検証するを繰り返す。 どこまで、意図したように動いているかを「確認」してみましょう。
Reikirin

2021/03/05 15:52

自力でデバッグができる様になりたいです。 どこまで意図したように動いているかを「確認」するデバッグはどうすればいいですか
phper.k

2021/03/05 15:53

質問に質問で返して悪いけど、どうすれば確認できると思いますか?
Reikirin

2021/03/05 16:10

初心者で、そもそもデバッグの概念自体もよく知らなかったのですが、Laravel+デバッグで検索したところ https://laraweb.net/practice/4298/ のページにわかりやすくまとめられていました。 1.Logファサードを使った、ログファイルに出力する方法(そもそもログファイルの見方がわからないので扱える自信はないですが) 2.Laravelに標準で入っているというTinkerというテスト(?)を使う方法 3.Laravelデバッグバーというアプリ(?)でロギングを取得してブラウザで確認する方法 4.先ほどphper.kさんに紹介していただいた、ヘルパーメソッドdump()とdd() があることがわかりましたが、ロギングしたものの読み取り方に自信がないので、どういったところに注目して進めていけば良いか教えていただきたいのですが、
phper.k

2021/03/05 16:12

とりあえず回答欄に移ります。 ここではみづらいので、
Reikirin

2021/03/05 17:21

ありがとうございました。 $items = Board::with('user')->orWhere('info_1', '%' . $request->info_1 . '%') ->orWhere('info_2', 'like', '%' . $request->info_2 . '%') ->orWhere('info_3', 'like', '%' . $request->info_3 . '%') ->orWhere('info_4', 'like', '%' . $request->info_4 . '%') ->orWhere('info_5', 'like', '%' . $request->info_5 . '%') ->get(); の様に'like'を挟んだところ、上手く$itemsを取得できる様になりました。 デバッグの知識を教えていただき本当にありがとうございました。 今後の開発においても今回で学んだことを生かしていきたいと思います。
guest

回答1

0

ベストアンサー

php

1 2 3 public function post(Request $request) 4 { 5 // dd($request); // さっきはここに書いてメソッドが呼び出されていることは確認済み 6 $user = Auth::user(); 7 $items = Board::with('user')->where('info_1', '%' . $request->info_1 . '%') 8 ->where('info_2', '%' . $request->info_2 . '%') 9 ->where('info_3', '%' . $request->info_3 . '%') 10 ->where('info_4', '%' . $request->info_4 . '%') 11 ->where('info_5', '%' . $request->info_5 . '%') 12 ->get(); 13 14 // ①ここに書けば、少なくともSQL問い合わせができているかを確認できる 15 dd($items); 16 17 $param = [ 18 'info_1' => $request->info_1, 19 'info_2' => $request->info_2, 20 'info_3' => $request->info_3, 21 'info_4' => $request->info_4, 22 'info_5' => $request->info_5, 23 'user' => $user, 24 'items' => $items, 25 ]; 26 27 // ②ここに書けば、ここまで動いていることが確認できる 28 dd($param); 29 return view('hello/index', $param); 30 }

投稿2021/03/05 16:15

phper.k

総合スコア3923

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

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

Reikirin

2021/03/05 16:21

回答ありがとうございます。例えば、先ほど私が行った実行結果で、#json: null の表示があったので、値が取得されていない、即ちpost()メソッドが正常に実行されていないのかな? とか思ったりしていたんですが、実際は実行されているとおっしゃられていたので、判断の基準としては、文の羅列が返ってきたら、動いている、という判断でよろしいですか?
phper.k

2021/03/05 16:25

dd() で何を確認しているかわかってますか? 場所によって、dd($items); dd($param); と引数に入れているものを変えている意味、読み取ろうとしてますか?
Reikirin

2021/03/05 16:35

全てdd($request)だと勘違い(見間違え?)していました、、、実際はdd($items); dd($param);なんですね、注意します。 入力結果は以下になりました。 ① Illuminate\Database\Eloquent\Collection {#1275 ▼ #items: [] } ② array:7 [▼ "info_1" => "入力値" "info_2" => "入力値" "info_3" => "入力値" "info_4" => "入力値" "info_5" => "入力値" "user" => App\Models\User {#1275 ▶} (ログインしていないときはここが null) "items" => Illuminate\Database\Eloquent\Collection {#1275 ▶} ]
phper.k

2021/03/05 16:36

そこで、結果帰ってきていることが、そこまでは実行できていることの証明になりませんか?
Reikirin

2021/03/05 16:41

はい、ようやく意味がわかりました、、、 ちなみに①で #items: [] が空なのが原因であることもわかりました(なぜか入力値を取得できていない?)
phper.k

2021/03/05 16:44

空と言うことは、SQLの検索条件に間違いがあるんでしょう。 実行されているSQLが間違っている、または、該当するデータがない、などの原因が挙げられる。 ここまでは説明省いていいですよね。 「実行されているSQLが正しいかどうかを調べる方法」ググってみてください
phper.k

2021/03/05 17:32

ん?これで解決???
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問