1

最初のクエリで 2 番目のクエリと同じ結果を返す方法を誰か説明してもらえますか? 最初のクエリは、カウントが 0 の列に対して 0 ではなく 1 を返します。2 番目のクエリは正常に動作します。COUNT() ステートメントに問題があると確信しています。

$lists = DB::select('favorites_lists.*', array(DB::expr('COUNT("favorites.list_id")'), 'total_favs'))
    ->from('favorites_lists')
    ->join('favorites', 'LEFT')
    ->on('favorites_lists.id', '=', 'favorites.list_id')
    ->where('favorites_lists.uid', '=', $user->id)
    ->group_by('favorites_lists.id')
    ->execute()
    ->as_array();

$lists = DB::query(
    Database::SELECT,
    'SELECT favorites_lists.*, COUNT(favorites.list_id) as total_favs
    FROM favorites_lists
    LEFT JOIN favorites
    ON favorites_lists.id = favorites.list_id
    WHERE favorites_lists.uid = ' . $user->id . '
    GROUP BY favorites_lists.id'
)
    ->execute()
    ->as_array();
4

1 に答える 1

2
DB::select('favorites_lists.*', array(DB::expr('COUNT("favorites.list_id")'), 'total_favs'))

この配列の用途は何ですか? 私は通常、このようにクエリを書きます。

DB::select('favorites_lists.*',DB::expr('COUNT("favorites.list_id") AS total_favs'))
于 2013-09-17T12:13:08.280 に答える