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

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

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

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

Q&A

解決済

2回答

2094閲覧

laravelであいまい検索の記述の仕方がわからないです

Ms.yy

総合スコア83

Laravel

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

0グッド

0クリップ

投稿2019/12/31 12:11

編集2019/12/31 14:10

前提・実現したいこと

フォームで入力した値が含まれていたら該当する単語だけ検索結果に表示したいのですが、Controllerはどの様なコードを記述すれば良いでしょうか?

index.blade.php

<form action="/search2" method="post"> @csrf ICO.Search:<input type="text" name="word" size="40"> <input type="submit" value="検索"> </form>

PostController

public function search2(Request $request){ $posts = Post::latest()->get(); $test = $request->word; $word= Post::where('title', 'like', '%$test%')->get(); return view('posts.search2')->with([ 'posts' => $posts, 'word' => $word ]); }

web.php

Route::post('/search2', 'PostsController@search2');

###search2.php(index.blade.phpからの表示先)

<p> 送られてきた変数は{{$word}} </p>

試したこと

PostControllerの"%$test%"を部分をダブルクォーテーションにしてみた

index.blade.phpの検索フォームで「a」と入力したらtitleに該当するaを含んだレコードが表示される ※この場合AUGがタイトル [{"id":7,"title":"AUG","body":"fff","created_at":"2019-12-22 22:46:29","updated_at":"2019-12-22 22:46:29"}]

###表示のさせ方
画像の1の後の部分がDBのtitleです。
titleの部分が「a」と含まれる物だけを画像の様に表示させたいです。
この場合はAUGだけです。

画像の上部に配列がありますが、これは「t」と検索したらtitleにtが含まれるtitle2,title3が表示されています。
しかし、titleカラムだけではなくtが含まれるレコードがまで表示されています。
これをtitleだけ抽出したいです。

イメージ説明

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

OS:mac
phpバージョン7.1
laravelを使用(バージョン5.8)
index.blade.phpのwordはPostControllerに渡っています。

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

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

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

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

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

m.ts10806

2019/12/31 12:24

Laravelはバージョン提示されないと答えようがないです。 PHPの場合、OSのMacは回答にはほぼ意味のない情報です。 PHPのバージョンのほうが有用です。
Ms.yy

2019/12/31 12:40 編集

失礼しました。バージョンが5.8です。 コードの問題点としましては、 PostControllerの $test = $request->word; $word= Post::where('title', 'like', '%$test%')->get(); ではindex.blade.phpから送られた値が含まれている検索結果が表示されません。
guest

回答2

0

$test = $request->word;

$word= Post::where('title', 'like', '%$test%')->get();

シングルクォーテーションでは変数展開されません。

PHP

1$hoge = "test"; 2 3echo "$test".PHP_EOL; 4echo '$test'.PHP_EOL; 5echo $test.PHP_EOL; 6

投稿2019/12/31 12:47

m.ts10806

総合スコア80850

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

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

Ms.yy

2019/12/31 13:05

試してみましたが、想定している内容と違う形で表示されてしまいます。 $word= Post::where('title', 'like', '%$test%')->get(); のtestの部分をダブルクォーテーションで囲った結果送られたきた値を含むレコードが表示されてしまいます。
m.ts10806

2019/12/31 13:08

クエリビルダではなくSQL文でどういうコードを組みと結果を得られるかイメージできてますか? また、そもそもですがこれはSQLの問題ではないのではないでしょうか。 「該当する単語だけ」というのは要は「検索に使った単語だけ」なのであれば、 POSTした値そのまま表示すれば良いだけなのではないでしょうか。 いずれにしても 「どういうデータがあり」「どういう検索ワードを送ったら」「どういう結果が得られ」「どう表示したいのか」を具体的に記載いただく必要があります。
m.ts10806

2019/12/31 13:21

送られた=入力された文字 でしたら $request->word をそのまま渡せばおしまいでは。DB観に行く必要ないのでは。 「どういうデータがあり」「どういう検索ワードを送ったら」「どういう結果が得られ」「どう表示したいのか」を具体的に。 「どういう結果が得られ」「どう表示したいのか」が具体的ではないです。 もし”AUG”を表示したいのでしたらコレクションからそのtitleとやらにアクセスすれば良いだけです。 https://readouble.com/laravel/5.8/ja/collections.html
Ms.yy

2019/12/31 13:41

$request->wordでしたらただ値を渡してしまうだけとなってしまいます。 分かりづらくて申し訳ございません。 今回は検索フォームから送られたきた値が含まれる物だけを表示させたいです。 例えば、検索フォームに「a」を入力したらDBのtitleカラムから「a」が含まれるものだけを検索結果として表示させたいです。
m.ts10806

2019/12/31 13:46

title like '%a%' の結果が出てるのなら正しいのでは。 「どう表示したいのか」が具体的に提示されてないままなので、なんとも。
Ms.yy

2019/12/31 14:04

表示の仕方としましては、DBのtitleカラムに「a」と含まれている物だけを画面上に表示させたいです。 資料として画像を添付させて頂きました。
m.ts10806

2019/12/31 14:09

>DBのtitleカラムに「a」と含まれている物だけ いえ、ですから、会話成り立ってません。 「どう表示させたいか」ですよ。それは「何を」です。まあ「何を」も具体的ではないですけど。 画像添付も出来てないようですけど・・ ↓こう出てるんですよね。 > [{"id":7,"title":"AUG","body":"fff","created_at":"2019-12-22 22:46:29","updated_at":"2019-12-22 22:46:29"}] それは、title like '%a%' の結果なのは間違いないんですよね? だったら「正しい」というのがこちらの見解です。 ここからどうしたいのかが誰にも伝わってません。
退会済みユーザー

退会済みユーザー

2019/12/31 14:09

@Ms.yy さん 「DBのtitleカラムに「a」と含まれている物だけを画面上に表示させたい」ではなく、「大文字と小文字を区別して検索したい」というのが本題なのでは?
m.ts10806

2019/12/31 14:13

Kosuke_Shibuyaさん だといいなぁと思いながら、具体的な例が出てこないのでこちらも踏み出せてないわけで。
退会済みユーザー

退会済みユーザー

2019/12/31 14:14

と思ったら、それでもなかったという・・・
m.ts10806

2019/12/31 14:29

となると。 Post::where('title', 'like', '%$test%')->get() の結果をループさせればいいだけですよねぇ。 latest()って確か単なるソート機能ですし。
Ms.yy

2020/01/01 01:08 編集

ありがとうござます。 ループでtitleだけ取り出し理想としていた表示の仕方が行けました!
m.ts10806

2020/01/02 02:40

何があってどう出したいのか明示されてないので誰にも回答不可能ですよ。 必要なことをやらないなら質問しない方がお互いのためです。
guest

0

自己解決

Controllerの部分を下記の様な形で記述し、送られてきた$recordwords(配列)をblade側でtitleだけ抽出したら理想としていた形になりました。

=>Controller
$record = $request->word;
$recordwords= Post::where('title', 'like', "%{$record}%")->get();

投稿2020/01/02 02:04

Ms.yy

総合スコア83

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問