我有两个模型:posts
和likings
,它们有一对多的关系(所以,一个帖子有很多喜欢)。 Likings模型还有一个isActive
字段,表明喜欢是主动的还是被动的。
我想获得(排序)前5个帖子,这些帖子已经收到了最大的“活跃”喜欢(只有喜欢其isActive字段为true的帖子才会被考虑)。
这是查询:
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配置(可能删除ONLY_FULL_GROUP_BY
模式)是不合逻辑的,但查询中的变化最小。
应对每个非聚合字段进行分组。
它是标准行为,在mysql中,取决于ONLY_FULL_GROUP_BY模式。
在> = 5.7
中默认启用此模式。
select posts.id, post.user_id, 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, posts.user_id
order by likes_count desc
limit 5
或者,你可以aggregate
它:
select posts.id, MIN(post.user_id), 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
其他方式 - 改变sql_mode
:
SET SESSION sql_mode = '';
此外,您可以将其分为2个查询:
IN clause
)在5.7中,sqlmode默认设置为:
ONLY_FULL_GROUP_BY,NO_AUTO_CREATE_USER,STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION
要删除ONLY_FULL_GROUP_BY子句,您可以执行以下操作:
SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));