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

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

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

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

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

2回答

3163閲覧

LaravelのEloquentで別のデータテーブルを集計してソートしたい

oh...

総合スコア8

PHP

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

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2018/08/12 01:13

初心者で恐縮なのですが、質問させてください。
Laravel、EloquentのorderByを使ってデータベースから取得した情報をソートしたいと思っています。

記事(mutters)と、そのレビュー(revues)のテーブルがあると仮定します。

mutters
========
id
title
text
========

revues
========
id
star(レビューの星の数)
mutter_id
========

muttersはいくつものレビューを持っています(hasmanyの関係)。
そのレビューの平均でソートしたいと考えています。

Laravel

1//やりたいこと 2$mutters = Mutter::orderBy('revues->starの平均値', 'desc')->paginate(20);

分かる方がいましたらご教授いただければと思います。
またデータベースから見直した方が良いなどの意見がありましたらお願いいたします。

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

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

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

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

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

guest

回答2

0

こちら解決したと思ったのですが、get()してしまうとページネーションできないっぽいです。

投稿2018/08/17 03:55

編集2018/08/21 13:57
oh...

総合スコア8

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

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

0

以下、サンプルです。
取得したデータベースコレクションをsortByを使って並び替えています。

Controller(抜粋)

php

1 /** 2 * Display a listing of the resource. 3 * 4 * @return \Illuminate\Http\Response 5 */ 6 public function index() 7 { 8 $matterCollections = Matter::with('reviews')->get(); 9 $matters = $matterCollections->sortByDesc(function($matter){ 10 return $matter->reviews->avg('stars'); 11 }); 12 return view('test')->with('matters',$matters); 13 }

テスト用ビュー

@extends('layouts.app') @section('content') <div class="container"> <table class="table table-striped table-bordered table-hover"> <tr> <th>ID</th> <th>タイトル</th> <th>本文</th> <th>スターの平均</th> </tr> @foreach ($matters as $matter) <tr> <td>{{$matter->id}}</td> <td>{{$matter->title}}</td> <td>{{$matter->text}}</td> <td>{{$matter->reviews->avg('stars')}}</td> </tr> @endforeach </table> </div> @endsection

データベース

matters(記事)テーブル

php

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

レビューテーブル

php

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

Controller(抜粋)

php

1 /** 2 * Display a listing of the resource. 3 * 4 * @return \Illuminate\Http\Response 5 */ 6 public function index() 7 { 8 $matters = Matter::with('reviews')->get(); 9 $value = $matters->sortByDesc(function($matter){ 10 return $matter->reviews->avg('stars'); 11 }); 12 return view('test')->with('matters',$value); 13 }

投稿2018/08/17 02:18

motuo

総合スコア3027

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

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

oh...

2018/08/17 03:58

motuoさん、ご回答いただきありがとうございました! まさに求めていた答えでした。 今回はmuttersに評価の平均カラムを作ってそれでソートしてしまいましたが、次回からはこの方法を試したいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問