當我將以下查詢貼到我的SQL工具中時,它可以正常運行,但是透過Laravel運行時傳回零行。
$sql = " SELECT main_query.* FROM ( SELECT c.id, c.name, c.order, cd.case, (SELECT count(*) from logs cl where c.id = cl.id and cl.status = 'OPEN' ) as cl_count, sdsc.task FROM `table` c INNER JOIN `table2` cd ON (c.id = cd.id) LEFT JOIN `table3` sdsc ON (c.id = sdsc.id) WHERE c.status = 'NEW' GROUP BY c.id ORDER BY cd.updated_at DESC ) main_query where main_query.cl_count > 1 GROUP BY main_query.id ORDER BY main_query.updated_at DESC limit 0,20 ";
由於實際查詢的複雜性,我無法完全將其轉換為Eloquent查詢,因此我使用DB::select(DB::raw($searchQuery));
來執行它。
如果我刪除where main_query.cl_count > 1
,查詢就可以正常運作。是什麼導致它失敗,並且我該如何重寫程式碼?
P粉5178143722024-01-17 11:29:37
嘗試以下程式碼,由https://sql2builder.github.io/產生
DB::query()->fromSub(function ($query) { $query->from('table') ->select('table.id', 'table.name', 'table.order', 'table2.case', 'table3.task') ->on(function ($query) { $query->where('table.id','=','table2.id'); }) ->on(function ($query) { $query->where('table.id','=','table3.id'); }) ->where('table.status','=','NEW') ->groupBy('table.id') ->orderBy('','desc'); },'main_query') ->select('main_query.*') ->where('main_query.cl_count','>',1) ->groupBy('main_query.id') ->orderBy('','desc') ->get();