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. mysql 可以從 TCP 連接但是不能從 socket 鏈接2. java - jdbc如何返回自動(dòng)定義的bean3. javascript - 按鈕鏈接到另一個(gè)網(wǎng)址 怎么通過百度統(tǒng)計(jì)計(jì)算按鈕的點(diǎn)擊數(shù)量4. mysql updtae追加數(shù)據(jù)sql語句5. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。6. Python處理Dict生成json7. 大家都用什么工具管理mysql數(shù)據(jù)庫?8. python - 請(qǐng)問這兩個(gè)地方是為什么呢?9. 請(qǐng)教一個(gè)mysql去重取最新記錄10. mysql的循環(huán)語句問題
