有人能解释一下如何让第一个查询返回与第二个查询相同的结果吗?对于计数为0的任何列,第一个查询返回1而不是0。第二个查询工作正常。我很确定这是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();发布于 2013-09-17 12:13:08
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'))https://stackoverflow.com/questions/18829950
复制相似问题