我有兩種模式:posts
和likings
它們有一對多的關係(所以,一個職位有很多喜歡)。 Likings模型還有一個isActive
字段,顯示喜歡是主動還是被動。如何解決「不在GROUP BY」錯誤在mysql查詢
我想得到(排序)前5個已收到最多「活躍」喜歡的帖子(只有喜歡其isActive字段是真的會被考慮)。
這是查詢:
select posts.*, count(likings.id) as likes_count from 'posts'
left join 'likings' on 'likings'.'post_id' = 'posts'.'id' and 'likings'.'isActive' = 1
group by 'posts'.'id'
order by 'likes_count' desc
limit 5
這是從這個laravel查詢結果:
Post::selectRaw('posts.*, count(likes.id) as likes_count')
->leftJoin('likes', function ($join) {
$join->on('likes.post_id', '=', 'posts.id')
->where('likes.is_active', '=', 1);
})
->groupBy('posts.id')
->orderBy('likes_count', 'desc')
->take(5)
->get();
這是錯誤:
SQLSTATE[42000]: Syntax error or access violation: 1055
'database.posts.user_id' isn't in GROUP BY
這裏,posts.user_id
也是posts
表的字段並顯示該帖子的所有者。
如何解決此錯誤?看起來改變mysql config(可能刪除ONLY_FULL_GROUP_BY
模式)是不合邏輯的,但是查詢中的最小改變。
按照標準,您必須列出'group clause'中的每個選定字段或使用聚合函數之一。 –