了解mysql concat()函数


 

concat(arg1,arg2,....):将形参对应字段的值组合成一个字符串

假设:现在有一张学生表(test_user)

将这三个字段组合成一个字符串作为第四个字段

select test_user.*,
    concat(test_user.id,test_user.`name`,test_user.sex) as introduction
    from 
        test_user 
    GROUP BY `name`;

但是查询出来的数据没有分割符,可以在concat中加入常量

select test_user.*,
    concat(test_user.id,',',test_user.`name`,',',test_user.sex) as introduction
    from 
        test_user 
    GROUP BY `name`;

这样写如果分隔符都一样,又要一直加,那不是很麻烦。

mysql提供另一个函数concat_ws(separator,arg1,arg2,.....),第一个参数为分隔符,第二个以后的参数为字段名

select 
    u.*,
    concat(u.id,',',u.`name`,',',u.sex) as introduction,
    CONCAT_WS('.',u.id,u.`name`,u.sex) as xinxi
  from test_user u GROUP BY u.`name`;

这些只是对单条记录数据的拼接。

 

现在多了张课程表(test_subject)

想查询每个学生的课程有哪些

select * from test_user LEFT JOIN test_subject on test_user.id = test_subject.user_id;

但是这样看起来不够直观。那就干脆先按名称分组。

select 
  *
from
  test_user LEFT JOIN test_subject
on test_user.id = test_subject.user_id
GROUP BY test_user.`name`;

但是分完组之后,课程只剩下一个了,没有达到预期的要求,

mysql提供一个函数GROUP_CONCAT(arg1),内部的形参在分组时,则在arg1字段中将属于该分组的值字段进行拼接,拼接顺序会被order by影响

select 
  test_user.*,
  GROUP_CONCAT(test_subject.`subject`) as `subject`
from
  test_user LEFT JOIN test_subject
on
  test_user.id = test_subject.user_id
GROUP BY
  test_user.`name`;

完成。清晰明了的显示各个学生所有的科目。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM