文章詳情頁
mysql 如何分組?
瀏覽:163日期:2022-06-10 15:27:45
問題描述
假設user表
idnamegroup1evanadmin1evan1admin1evan2admin1evan3user1evan4userselect * from user group by user.group 出來的數據只有2條,而不是 user.group 為admin的一組,user.group 為 user 的為一組
求解,mysql 怎么把數組分組?感覺蠻多地方需要用到分組。
問題解答
回答1:沒有看太懂你的意思,用 group by user.group 就會出現2條,因為你的數據里只有 admin 和 user 兩種 group 數據。
分組 是需要結合 count, sum 等統計方法使用的。
如果你要的是admin的數據在一起,user 的數據在一起,那就直接 order by user.group 就好了
回答2:用GROUP BY子句的話,如果只有一個條件的話,只按照該條件滿足的所有唯一值,一個為一條數據。對于GROUP BY user.group,你只有兩種唯一值:user和admin,所以就只會有兩條數據。
如果你想將相同user.group的數據放在一起,正如樓上所說,直接使用排序即可。
如果你想要相同的user.group合并成一行且不丟失user.name數據,可以使用GROUP_CONCAT()函數,將所有組內的name合并成逗號分隔的字符串(當然可以改成其他分隔符)
SELECT *, GROUP_CONCAT(user.name) FROM user GROUP BY user.group
相關文章:
1. 為什么我ping不通我的docker容器呢???2. nignx - docker內nginx 80端口被占用3. python3.x - python連oanda的模擬交易api獲取json問題第五問4. angular.js - angular內容過長展開收起效果5. java - SSH框架中寫分頁時service層中不能注入分頁類6. 關于docker下的nginx壓力測試7. docker鏡像push報錯8. javascript - js代碼獲取驗證碼倒計時問題9. dockerfile - [docker build image失敗- npm install]10. html5 - 百度echart官網下載的地圖json數據亂碼
排行榜
