2015-11-08 92 views
7

我有两种模式:postslikings它们有一对多的关系(所以,一个职位有很多喜欢)。 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模式)是不合逻辑的,但是查询中的最小改变。

+0

按照标准,您必须列出'group clause'中的每个选定字段或使用聚合函数之一。 –

回答

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查询:

  1. 获取聚合和帖子ID
  2. 获取与获取的IDS数据发布(与IN clause
+0

我需要帖子的所有字段。我不能用帖子开始查询。* – horse

+0

你可以,但是你不能在group子句中这样做。其他选项是在'mysql' config或会话中更改'sql_mode' –

+0

也许我应该多写一个查询。 – horse

1

在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','')); 
+0

如果我们这样做会导致任何问题吗? – BhargavSushant