我有两种模式: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'中的每个选定字段或使用聚合函数之一。 –