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

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

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

Laravel 6は、オープンソースなPHPのフレームワーク。Webアプリケーションの開発に適しており、バージョン6はLTSです。5.8での向上に加えて、セマンティックバージョニングの採用やLaravel Vaporとのコンパチビリティなどが変更されています。

Laravel

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

PHP

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

解決済

Laravelでランキングサイトで検索機能を追加。検索した後にランキングの値が変わってしまう。

haya1996
hatena

総合スコア4

Laravel 6

Laravel 6は、オープンソースなPHPのフレームワーク。Webアプリケーションの開発に適しており、バージョン6はLTSです。5.8での向上に加えて、セマンティックバージョニングの採用やLaravel Vaporとのコンパチビリティなどが変更されています。

Laravel

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

PHP

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

1回答

0評価

0クリップ

216閲覧

投稿2022/06/29 11:48

人気ランキングサイトを作成しています。
検索機能は、実装出来ました。
しかしエラーも出ず、検索も出来ていますが、
順位(rank)だけが引き継がれず、全員1位になってしまいます。(他のデータは、ちゃんと反映される。)
どのようにすれば、引き継がれるのか教えて頂きたいと思い質問しました。
よろしくお願いします。

FighterController <?php namespace App\Http\Controllers; use Illuminate\Http\Request; //Fighterモデルをインポート use App\Fighter; //Likeモデルをインポート use App\Like; (省略) // DBをインポート use DB; class FighterController extends Controller { //トップページ public function index(Request $request) { //いいねのカウント、いいねが多い順に並び替え、順位を付ける $fighters_date = Fighter::query() ->selectRaw('fighters.*') ->addSelect(DB::raw('count(likes.user_id) as likes_count')) ->addSelect(DB::raw('rank() over (order by count(likes.user_id) desc) as rank')) ->leftJoin('likes', 'fighters.id', '=', 'likes.fighter_id') ->groupBy('fighters.id') ->orderByRaw('count(likes.user_id) desc'); //検索機能 $keyword = $request->input('keyword'); //ユーザーが検索したら if(!empty($keyword)) { // 選手名を検索 $fighters_date->where('fighter_name', 'LIKE', "%{$keyword}%"); } $fighters = $fighters_date->get(); return view('fighters.index',[ 'title' => '格闘家人気ランキング', 'fighters' => $fighters, 'keyword' => $keyword, ]); }
index.blade.php (省略) <form method = "GET" action = "{{ route('fighters.index') }}"> <input type = "text" name = "keyword" value = "{{ $keyword }}" placeholder = "選手名検索"> <input type = "submit" value = "検索"> </form> (省略)
検索後の$fightersの中身 index.blade.php Illuminate\Database\Eloquent\Collection {#1230 ▼ #items: array:1 [▼ 0 => App\Fighter {#1238 ▼ #fillable: array:4 [▶] #connection: "mysql" #table: "fighters" #primaryKey: "id" #keyType: "int" +incrementing: true #with: [] #withCount: [] #perPage: 15 +exists: true +wasRecentlyCreated: false #attributes: array:9 [▼ "id" => 5 "fighter_name" => "那須川 天心" "image" => "photos/Xv0gk3zVPCbU341krqEdKZm5F3OOs4daTXP1AkTh.jpg" "image_quote" => "RISE公式サイトより引用" "account" => "https://twitter.com/TeppenTenshin" "created_at" => "2022-06-26 16:22:51" "updated_at" => "2022-06-26 16:22:51" "likes_count" => 0 "rank" => 1 ] #original: array:9 [▶] #changes: [] #casts: [] #dates: [] #dateFormat: null #appends: [] #dispatchesEvents: [] #observables: [] #relations: [] #touches: [] +timestamps: true #hidden: [] #visible: [] #guarded: array:1 [▶] } ] }

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Laravel 6

Laravel 6は、オープンソースなPHPのフレームワーク。Webアプリケーションの開発に適しており、バージョン6はLTSです。5.8での向上に加えて、セマンティックバージョニングの採用やLaravel Vaporとのコンパチビリティなどが変更されています。

Laravel

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

PHP

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