子查詢

當我想要計算子查詢的數量時,會想要執行像下方的 SQL 查詢語法

SELECT count(*)
FROM (
    SELECT UID
    FROM `posts`
    WHERE `status` = 1
    GROUP BY `user_id`
) sub

在 Eloquent 可以用下面方式達到子查詢的目的

<?php

// Eloquent Builder instance
$SubQuery = Posts::where('status', 1)
    ->groupBy('user_id');

$count = DB::table( DB::raw("({$SubQuery->toSql()}) as sub") )
    ->mergeBindings($SubQuery->getQuery())
    ->count();

記得當你的子查詢結束後,若有更多的條件需要執行,則必須將查詢條件放在 mergeBindings() 方法後方,否則原本 SubQuery 的查詢資料順序會綁定錯誤

$count = DB::table( DB::raw("({$SubQuery->toSql()}) as sub") )
    // ->where(..) 這裡會出錯
    ->mergeBindings($SubQuery->getQuery())
    // ->where(..) 正確
    ->count();

Laravel v5.6.12 (2018-03-14) 之後,加入了 fromSub()fromRaw() 的方法可以直接產生子查詢語法

<?php
DB::query()->fromSub(function ($query) {
    $query->from('posts')
        ->where('status', 1)
        ->groupBy('user_id');
}, 'sub')->count();

// select count(*) as aggregate from (select * from `abc` group by `col1`) as `a`

參考資料

results matching ""

    No results matching ""