日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發布時間:2025/3/12 数据库 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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模式)是不合邏輯的,但查詢中的變化最小.

總結

以上是生活随笔為你收集整理的php mysql group by_php – 如何在mysql查询中解决“不在GROUP BY中”错误的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。