2013-09-16 35 views
1

有人可以解釋如何讓第一個查詢返回與第二個查詢相同的結果嗎?對於計數爲0的任何列,第一個查詢返回1而不是0。第二個查詢正常工作。我很確定這是COUNT()語句的問題。Kohana DB表達式不能返回正確的結果

$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(); 

回答

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')) 
+1

這就是Kohana文檔在他們的例子中顯示的內容。我取消註釋了我的原始代碼,現在它正在工作。我不知道是什麼改變了,但是在我所有的調試都顯示錯誤的結果來自數據庫之前,所以我不知道。你的表情工作得很好,所以我會繼續,並將你的答案標記爲已接受。如果有任何內容,這篇文章將幫助人們試圖通過Kohana的不完整和令人困惑的文檔:)但有一件事,最後你需要一個額外的括號。 – Gavin