mysql分组后合并显⽰⼀个字段的多条数据⽅式
⽬录
mysql分组合并显⽰⼀个字段多条数据
表中数据如下
mysql多字段分组
mysql多字段分组
GROUP BY与ORDER BY⼀起使⽤(分组排序)
使⽤having过滤分组
mysql分组合并显⽰⼀个字段多条数据
⾸先我们有⼀张学⽣兴趣表(student_hobby),字段包括主键(id)、姓名(name)、兴趣(hobby)
表中数据如下
id name hobby
0⼩明篮球
1⼩明跑步
2⼩华读书
然后我们想让他显⽰成如下效果。
name hobbies
⼩明篮球,跑步
⼩华读书
那么我们可以使⽤如下SQL。
select name,group_concat(hobby separator ',') hobbies from student_hobbt group by name;
其中分隔符逗号也可以替换为其他想要使⽤的字符。
mysql多字段分组
mysql多字段分组
group by 语法
分组查询是对数据按照某个或多个字段进⾏分组,MYSQL中使⽤group by关键字对数据进⾏分组,基本语法形式为: [GROUP BY 字段][HAVING <;条件表达式>]
多字段分组
使⽤GROUP BY可以对多个字段进⾏分组,GROUP BY关键字后⾯跟需要分组的字段,MYSQL根据多字段的值来进⾏层次分组,分组层次从左到右,即先按照第1个字段分组,然后在第1个字段值相同的记录中,再根据第2个字段的值进⾏分组,以此类推。
GROUP BY与ORDER BY⼀起使⽤(分组排序)
某些情况下需要对分组进⾏排序,order by⽤来对查询的记录排序,如果和GROUP BY⼀起使⽤,就可以完成对分组的排序
例如下表:
将上表中数据按照wellid和年⽉的格式分组统计:
sql语句:
select wellid,sum(number) as sum,DATE_FORMAT(time,'%Y-%m') as createTime
from well
GROUP BY wellid,createTime
order by createTime;
统计结果:
使⽤having过滤分组groupby分组
GROUP BY可以和HAVING⼀起限定显⽰记录所需要满⾜的条件,只有满⾜条件的分组才会被显⽰还是上⾯张表,我们这次限定只要2020年12⽉之后的数据:
select wellid,sum(number) as sum,DATE_FORMAT(time,'%Y-%m') as createTime
from well
GROUP BY wellid,createTime
having createTime>'2020-12'
order by createTime;
查询结果:
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论