{category}

Laravel - 高度なクエリ

having()

ハビング(Eloquent ORM とデータベース操作

意味 グループ化後の条件指定


having()とは?

having()メソッドは、groupBy()でグループ化されたクエリ結果に対して条件を適用するためのEloquent ORMのメソッドです。これを使うと、集計結果に基づいてフィルタリングを行うことができます。

having()の具体的な使い方

条件付き集計

$users = DB::table('orders')
    ->groupBy('user_id')
    ->having('total_orders', '>', 10)
    ->select('user_id', DB::raw('COUNT(*) as total_orders'))
    ->get();

foreach ($users as $user) {
    echo "ユーザーID: {$user->user_id}, 注文数: {$user->total_orders}\n";
}

👇出力結果

ユーザーID: 1, 注文数: 15
ユーザーID: 3, 注文数: 12
ユーザーID: 5, 注文数: 11

この例では、注文テーブルからユーザーIDでグループ化し、10件以上の注文を持つユーザーのみを取得しています。groupByでユーザーIDごとにグループ化し、havingで注文数が10より大きいユーザーのみをフィルタリングしています。結果として、条件を満たすユーザーIDと、そのユーザーの注文総数のリストが返されます。

複数条件での集計

$products = DB::table('order_items')
    ->join('products', 'order_items.product_id', '=', 'products.id')
    ->groupBy('product_id', 'products.name')
    ->havingRaw('SUM(quantity) > ? AND AVG(price) > ?', [100, 1000])
    ->select('product_id', 'products.name', DB::raw('SUM(quantity) as total_sold'), DB::raw('AVG(price) as average_price'))
    ->get();

foreach ($products as $product) {
    echo "商品ID: {$product->product_id}, 商品名: {$product->name}, 総販売数: {$product->total_sold}, 平均価格: {$product->average_price}円\n";
}

👇出力結果

商品ID: 2, 商品名: 高級腕時計, 総販売数: 120, 平均価格: 15000円
商品ID: 5, 商品名: ブランドバッグ, 総販売数: 150, 平均価格: 12000円

この例では、注文項目テーブルと商品テーブルを結合し、商品ごとにグループ化しています。havingRawメソッドを使用して、総販売数が100を超え、かつ平均価格が1000円を超える商品のみをフィルタリングしています。複数の集計条件を組み合わせることで、より詳細な分析が可能になります。

having()に関するよくある質問

Q. havingとwhereの違いは?
A. havingはグループ化後の結果に対して条件を適用し、whereはグループ化前の個々のレコードに対して条件を適用します。havingは集計関数と共に使用されることが多いです。
Q. havingを使うタイミングは?
A. グループ化された結果に対して条件を適用したい場合に使います。例えば、「10件以上注文したユーザー」や「平均売上が1000円を超える商品」などを抽出する際に活用できます。
Q. havingは単独で使えますか?
A. 通常、havingはgroupByと組み合わせて使用します。groupByなしでhavingを使用すると、クエリ全体が1つのグループとして扱われるため、意図した結果が得られない可能性があります。

Laravelのhaving()についても学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、Laravelのhaving()やskip()、Model::all()、cursor()、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

よく使われる単語にだけ絞って学習することができるので、効率的にプログラミングが学習できます。

1日5分の暗記でプログラミンが身に付く!プログラミング単語帳 公式ストアで発売中!

HTML編、CSS編、JavaScript編、PHP編、Ruby編、その他単語編の6シリーズ分が公式ストアにて販売中です。気になった方はぜひ購入してみてください。


Laravelを学べる「プログラミング単語帳」アプリ

プログラミング単語帳がアプリになりました!Laravelはもちろん、10種類のプログラミング言語の中から、よく使われる単語をスマホで学習できます。

収録単語は2,000単語以上!
現在は、HTML、CSS、JavaScirpt、PHP、Laravel、Ruby、Python、MySQL、Linux、など10カテゴリーの単語帳が1つのアプリに収録されています。

いつでも、どこでも、隙間時間を有効活用して、プログラミングを効率的に学べるので、ぜひダウンロードしてみてください。

2024年7月アップデート情報:「Laravel」カテゴリーが追加されましました!

2024年8月アップデート情報:「MySQL」「Linux」カテゴリーが追加されましました!


関連するそのほかの単語

skip()

指定数のレコードを省略

種類: 高度なクエリ

Model::all()

全レコードを取得

種類: 基本的なクエリ

cursor()

データを順次処理

種類: 大量データ処理

assertViewIs()

使用ビューの確認

種類: レスポンスアサーション

__invoke()

単一アクションコントローラ用

種類: コントローラ