mysql 如何分組?
問題描述
假設(shè)user表
idnamegroup1evanadmin1evan1admin1evan2admin1evan3user1evan4userselect * from user group by user.group 出來(lái)的數(shù)據(jù)只有2條,而不是 user.group 為admin的一組,user.group 為 user 的為一組
求解,mysql 怎么把數(shù)組分組?感覺蠻多地方需要用到分組。
問題解答
回答1:沒有看太懂你的意思,用 group by user.group 就會(huì)出現(xiàn)2條,因?yàn)槟愕臄?shù)據(jù)里只有 admin 和 user 兩種 group 數(shù)據(jù)。
分組 是需要結(jié)合 count, sum 等統(tǒng)計(jì)方法使用的。
如果你要的是admin的數(shù)據(jù)在一起,user 的數(shù)據(jù)在一起,那就直接 order by user.group 就好了
回答2:用GROUP BY子句的話,如果只有一個(gè)條件的話,只按照該條件滿足的所有唯一值,一個(gè)為一條數(shù)據(jù)。對(duì)于GROUP BY user.group,你只有兩種唯一值:user和admin,所以就只會(huì)有兩條數(shù)據(jù)。
如果你想將相同user.group的數(shù)據(jù)放在一起,正如樓上所說,直接使用排序即可。
如果你想要相同的user.group合并成一行且不丟失user.name數(shù)據(jù),可以使用GROUP_CONCAT()函數(shù),將所有組內(nèi)的name合并成逗號(hào)分隔的字符串(當(dāng)然可以改成其他分隔符)
SELECT *, GROUP_CONCAT(user.name) FROM user GROUP BY user.group
相關(guān)文章:
1. javascript - sublime快鍵鍵問題2. javascript - immutable配合react提升性能?3. Apache 已經(jīng)把網(wǎng)站根目錄的改為allow from all了,但是服務(wù)器還是不能訪問?4. javascript - nodejs關(guān)于進(jìn)程間發(fā)送句柄的一點(diǎn)疑問5. css - 寫頁(yè)面遇到個(gè)布局問題,求大佬們幫解答,在線等,急!~6. 實(shí)現(xiàn)bing搜索工具urlAPI提交7. javascript - 移動(dòng)端上不能實(shí)現(xiàn)拖拽布局嗎?8. vue.js - Vue 如何像Angular.js watch 一樣監(jiān)聽數(shù)據(jù)變化9. 配置Apache時(shí),添加對(duì)PHP的支持時(shí)語(yǔ)法錯(cuò)誤10. phpstudy8.1支持win11系統(tǒng)嗎?

網(wǎng)公網(wǎng)安備