php mysql group by_php – 如何在mysql查询中解决“不在GROUP BY中”错误

我有两个模型:帖子和喜欢有一对多的关系(所以,一个帖子有很多喜欢). 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模式)是不合逻辑的,但查询中的变化最小.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值