MySQL拼接字符串函数GROUP_CONCAT详解
上一篇文章跨表更新,看到自己写的SQL像个憨憨写了关于跨表个更新的内容。一年过的很快,文中后来的两位员工馮大和馮二也要面对无情的KPI考核了,他们工作干的很不错,performance分别是4和5
新需求来了,静悄悄的来了!!!领导想要查看每个performance下都有谁,同时要求将这些人的名称要逗号拼接成一个字符串,也就是说要得到下面的结果:
要将结果集中某个指定的列进行字符串拼接,这要怎么做呢?主角闪亮✨登场
GROUP_CONCAT(expr)
在Mysql官方文档中,该函数被放在聚合函数章节,如果你要按照指定字段分组拼接,就要配合关键字GROUPBY来使用的
定义
该函数返回一个字符串结果,该字符串结果是通过分组串联的非NULL值。如果没有非NULL值,则返回NULL。完整语法如下:
GROUP_CONCAT([DISTINCT]expr[,expr...] [ORDERBY{unsigned_integer|col_name|expr} [ASC|DESC][,col_name...]] [SEPARATORstr_val])
What?这个语法看着太复杂了吧,别着急,下面会用例子慢慢说明逐一验证滴
使用案例
先完成文章开头的需求:
SELECTperformance,GROUP_CONCAT(employee_name)ASemployees FROMemployees GROUPBYperformance;
zou是这个结果:
到这里,领导给过来的需求就完成了