文章详情页
mysql 如何分组?
浏览:145日期: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. java - 原生CGLib内部方法互相调用时可以代理,但基于CGLib的Spring AOP却代理失效,为什么?3. javascript - js中递归与for循环同时发生的时候,代码的执行顺序是怎样的?4. CSS3可否做出这个效果?5. docker - 如何修改运行中容器的配置6. python - django models 为生成的html元素添加样式。7. html5 - 怎么用npm下载react3版本的路由呢。8. python中怎么对列表以区间进行统计?9. javascript - iframe 为什么加载网页的时候滚动条这样显示?10. css - 移动端 line-height安卓错位,苹果机正常用,缩放解决了,可是又出来了占位的问题
排行榜
