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

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

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

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

Q&A

解決済

1回答

371閲覧

掲示板のあいまい検索を実装したいです

fsdfsa

総合スコア11

Laravel

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

0グッド

0クリップ

投稿2023/06/08 13:20

編集2023/06/08 13:24

実現したいこと

Laravelで掲示板の作成をしています。投稿機能や編集削除など一通り備わったのですが、検索機能がうまくできません。
名前、投稿日、本文で成り立っている投稿を一覧で表示させていますが、本文をあいまい検索して、該当する投稿のみ表示させたいです。

前提

検索フォームを作成して、PostsController.phpに処理内容を記載しweb.phpでルーティングしました。特にエラーは表示されませんが、検索しても結果が反映されないです。

テーブル(カラム) posts(id、 post、 user_name、 created_at、 update_at)

該当のソースコード

index.blade.php

1@extends('layouts.app') 2 3 4@section('content') 5<div class='container'> 6 7 8 <div class='container'> 9 10 11{!! Form::open(['url' => 'post/create']) !!} 12 13<h5 class='page-header'>名前</h5> 14<div class="form-group"> 15{!! Form::input('text', 'name', null, ['required', 'class' => 'form-control', 'placeholder' => '名前']) !!} 16</div> 17 18<h5 class='page-header'>本文</h5> 19<div class="form-group"> 20{!! Form::input('text', 'newPost', null, ['required', 'class' => 'form-control', 'placeholder' => '投稿内容']) !!} 21</div> 22<div> 23 @if ($errors->any()) 24 <ul> 25 @foreach ($errors->all() as $error) 26 <li>{{ $error }}</li> 27 @endforeach 28 </ul> 29 @endif 30</div> 31 32<button type="submit" class="btn btn-success pull-right">投稿</button> 33 34{!! Form::close() !!} 35 36</div> 37 38<h2 class='page-header2'>投稿一覧</h2> 39 40 41@foreach ($lists as $list) 42 43 44<hr> 45<div class=user> 46 <span class=name>{{ $list->user_name }}</span> 47 <span class=created>{{ $list->created_at }}</span> 48</div> 49<div class=post>{{ $list->post}}</div> 50<a class="btn btn-primary" href="/post/{{ $list->id }}/update-form">編集</a> 51<a class="btn btn-danger" href="/post/{{ $list->id }}/delete"onclick="return confirm('こちらの投稿を削除してもよろしいでしょうか?')">削除</a> 52 53@endforeach 54 55<!-- 検索 --> 56<div class="col-sm-4" style="padding:20px 0; padding-left:0px;"> 57<form class="form-inline" action="{{url('/')}}"> 58 <div class="form-group"> 59 <input type="text" name="keyword" class="form-control" placeholder="名前を入力してください"> 60 </div> 61 <input type="submit" value="検索" class="btn btn-info"> 62</form> 63</div> 64 65</div> 66@endsection 67 68<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script> 69

PostsController.php

1 2 3public function index(Request $request) 4{ 5$list = DB::table('posts')->get(); 6return view('posts.index',['lists'=>$list]); 7 8 $keyword = $request->input('keyword'); 9 #もしキーワードがあったら 10 if(!empty($keyword)) 11 { 12 $list->where('post','like','%'.$keyword.'%'); 13 } 14 15} 16

web.php

1 2Route::get('/', [PostsController::class, 'index']); 3

試したこと

PostsControllerの処理内容が違うと思うのですが、クエリをいろいろ試したりしましたがうまくいかないです。

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

Laravelバージョン7

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

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

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

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

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

guest

回答1

0

ベストアンサー

PHP

1public function index(Request $request) 2{ 3$list = DB::table('posts')->get(); 4//return view('posts.index',['lists'=>$list]); 5 6 $keyword = $request->input('keyword'); 7 #もしキーワードがあったら 8 if(!empty($keyword)) 9 { 10 $list->where('post','like','%'.$keyword.'%'); 11 } 12 13return view('posts.index',['lists'=>$list]); 14} 15

投稿2023/06/08 14:23

kei344

総合スコア69400

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

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

fsdfsa

2023/06/08 14:38 編集

ご回答頂きありがとうございます。 訂正いたしましたが、検索結果が反映されないです、、 index.blade.phpの記述が間違っているのでしょうか
phper.k

2023/06/08 15:07

->get() してない
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問