mysql concat group_mysql函数GROUP_CONCAT()

mysql 中 GROUP_CONCAT()函数,主要用来处理一对多的查询结果,通常会结合GROUP BY一起使用。

语法:

1 GROUP_CONCAT([DISTINCT] expr [,expr ...]

2

3 [ORDER BY {unsigned_integer | col_name | expr}4

5 [ASC | DESC] [,col_name ...]]6

7 [SEPARATOR str_val])

测试数据:

学生表(student)

e44588eb225bc6574745583a1000a4b0.png

课程表(course)

8b2ae0866f5d638787478bec4abae937.png

学生选课表(stu_course)

dd3cb3aa73e3b700f79db3406e07ad7a.png

1. 查询所有学生的选课信息

1 SELECT

2 s.stu_id ASstudentId,3 s.stu_name ASstudentName,4 c.course_id AScourseId,5 c.course_name ASstudentCourse6 FROM

7 student s8 LEFT JOIN

9 stu_course sc10 ON

11 s.stu_id =sc.stu_id12 LEFT JOIN

13 course c14 ON

15 sc.course_id = c.course_id

结果:

9462dd5c85aa977341f72de406d4fc13.png

使用GROUP_CONCAT()函数将结果分组归集:

1 SELECT

2 s.stu_id ASstudentId,3 s.stu_name ASstudentName,4 GROUP_CONCAT(c.course_id) AScourseId,5 GROUP_CONCAT(c.course_name) ASstudentCourse6 FROM

7 student s8 LEFT JOIN

9 stu_course sc10 ON

11 s.stu_id =sc.stu_id12 LEFT JOIN

13 course c14 ON

15 sc.course_id =c.course_id16 GROUP BY

17 studentId

结果:

94bb905620b49211a1b74aa306d8d036.png

使用GROUP_CONCAT时会将数值类型的数据转化成二进制BLOB类型,可以用CAST(expr AS type)函数或CONVERT(expr, type)函数将数值类型的数据转化成字符串:

1 SELECT

2 s.stu_id ASstudentId,3 s.stu_name ASstudentName,4 GROUP_CONCAT(CAST(c.course_id AS CHAR)) AScourseId,5 GROUP_CONCAT(c.course_name) ASstudentCourse6 FROM

7 student s8 LEFT JOIN

9 stu_course sc10 ON

11 s.stu_id =sc.stu_id12 LEFT JOIN

13 course c14 ON

15 sc.course_id =c.course_id16 GROUP BY

17 studentId

结果:

49326dca255b8e3cb4efa5ff12724aa6.png

2. 若要将第一条记录中courseId按照从小到大的方式归集,则可以在使用GROUP_CONCAT() 时加上ORDER BY :

1 SELECT

2 s.stu_id ASstudentId,3 s.stu_name ASstudentName,4 GROUP_CONCAT(CAST(c.course_id AS CHAR) ORDER BY c.course_id) AScourseId,5 GROUP_CONCAT(c.course_name) ASstudentCourse6 FROM

7 student s8 LEFT JOIN

9 stu_course sc10 ON

11 s.stu_id =sc.stu_id12 LEFT JOIN

13 course c14 ON

15 sc.course_id =c.course_id16 GROUP BY

17 studentId

结果:

075d40930676c7a08ada3f0dca97b619.png

但我们发现,虽然courseId这一列的数据按照从小到大的顺序排序了,但另一列studentCourse对应的数据却并没有跟着变,这也算是GROUP_CONCAT的一个缺点了。若有人知晓如何让另一列也跟着变,还请不吝告知。

3. 改变分隔符。

GROUP_CONCAT默认的分隔符是逗号(”,”),若想换成其他分隔符,可以用 SEPARATOR关键字:

1 SELECT

2 s.stu_id ASstudentId,3 s.stu_name ASstudentName,4 GROUP_CONCAT(CAST(c.course_id AS CHAR) ORDER BY c.course_id SEPARATOR '/') AScourseId,5 GROUP_CONCAT(c.course_name SEPARATOR '|') ASstudentCourse6 FROM

7 student s8 LEFT JOIN

9 stu_course sc10 ON

11 s.stu_id =sc.stu_id12 LEFT JOIN

13 course c14 ON

15 sc.course_id =c.course_id16 GROUP BY

17 studentId

结果:

9a8f6d76b1f38877fdce99ae3fc8cfbd.png

4. GROUP_CONCAT长度限制

用了GROUP_CONCAT后,SELECT里如果使用了LIMIT是不起作用的.

用GROUP_CONCAT连接字段的时候是有长度限制的,并不是有多少连多少。但可以设置一下。

使用group_concat_max_len系统变量,可以设置允许的最大长度。

语法如下,其中 val 是一个无符号整数:

SET [SESSION | GLOBAL] group_concat_max_len = val;

若已经设置了最大长度, 则结果被截至这个最大长度。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值