mysql 如何分組?
問題描述
假設(shè)user表
idnamegroup1evanadmin1evan1admin1evan2admin1evan3user1evan4userselect * from user group by user.group 出來的數(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. node.js - webpack-dev-server正常運(yùn)行,webpack打包卻出錯(cuò),怎么辦?2. mysql 5個(gè)left關(guān)鍵 然后再用搜索條件 幾千條數(shù)據(jù)就會(huì)卡,如何解決呢3. javascript - webpack編譯后的文件不生效,未編譯的文件生效4. java - ehcache緩存用的是虛擬機(jī)內(nèi)存么?5. 這是什么情況???6. thinkphp3 count()方法必須加上字段?7. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。我要forsearch里面echo8. 輸入地址報(bào)以下截圖錯(cuò)誤,怎么辦?9. android - 哪位大神知道java后臺(tái)的api接口的對(duì)象傳到前端后輸入日期報(bào)錯(cuò),是什么情況?求大神指點(diǎn)10. python中return 語句與 分支語句連用問題
