MySQL拼接字符串函数GROUP_CONCAT详解

作者:日拱一兵 时间:2024-01-27 18:21:56 

上一篇文章 跨表更新,看到自己写的SQL像个憨憨写了关于跨表个更新的内容。一年过的很快,文中后来的两位员工 馮大馮二 也要面对无情的 KPI 考核了,他们工作干的很不错,performance 分别是 4 和 5

MySQL拼接字符串函数GROUP_CONCAT详解

新需求来了,静悄悄的来了!!! 领导想要查看每个 performance 下都有谁,同时要求将这些人的名称要逗号拼接成一个字符串,也就是说要得到下面的结果:

MySQL拼接字符串函数GROUP_CONCAT详解

要将结果集中某个指定的列进行字符串拼接,这要怎么做呢?主角闪亮✨登场

GROUP_CONCAT(expr)

在 Mysql 官方文档 中,该函数被放在聚合函数章节,如果你要按照指定字段分组拼接,就要配合关键字 GROUP BY 来使用的

MySQL拼接字符串函数GROUP_CONCAT详解

定义

该函数返回一个字符串结果,该字符串结果是通过分组串联的非NULL值。如果没有非NULL值,则返回NULL。完整语法如下:

GROUP_CONCAT([DISTINCT] expr [,expr ...]
      [ORDER BY {unsigned_integer | col_name | expr}
        [ASC | DESC] [,col_name ...]]
      [SEPARATOR str_val])

What? 这个语法看着太复杂了吧,别着急,下面会用例子慢慢说明逐一验证滴

使用案例

先完成文章开头的需求:


SELECT performance, GROUP_CONCAT(employee_name) AS employees
FROM employees
GROUP BY performance;

zou是这个结果:

MySQL拼接字符串函数GROUP_CONCAT详解

到这里,领导给过来的需求就完成了😜

客官请留步,您点的菜还没上完呢......

我们是国际化的团队,我们的家乡遍布五湖四海

MySQL拼接字符串函数GROUP_CONCAT详解

领导想关怀一下员工,要查看公司全部员工的家乡都有哪些地方。员工们可能来自同一个地方,所以要将结果集去重复,DISTINCT 关键字就派上用场了


SELECT GROUP_CONCAT(DISTINCT home_town)
FROM employees;

来看结果:

MySQL拼接字符串函数GROUP_CONCAT详解

领导的关怀遍布五湖四海啊......

文案要改了,领导的关怀是遍布四海五湖的, 那么 ORDER BY 关键字就派上用场了


SELECT GROUP_CONCAT(DISTINCT home_town ORDER BY home_town DESC) AS '领导关怀地区'
FROM employees;

-- 没我这么起变量的哈,还是汉语,我看你是疯了

MySQL拼接字符串函数GROUP_CONCAT详解

这里你看到 GROUP_CONCAT 函数拼接字符串默认的分隔符是逗号 ,, 领导不开心,逗号么的感情,要用❕才能体现出关怀的强烈, SEPARATOR 关键字就派上用场了

分组拼接的值之间默认分隔符是逗号(,)。要明确指定分隔符,需要使用 SEPARATOR 关键字,紧跟其后的是你想设置的分隔符。要完全消除分隔符,就在 SEPARATOR 关键字后面写 '' 就好了

SELECT GROUP_CONCAT(DISTINCT home_town ORDER BY home_town DESC SEPARATOR '!') AS '领导关怀地区'
FROM employees;

MySQL拼接字符串函数GROUP_CONCAT详解


SELECT GROUP_CONCAT(DISTINCT home_town SEPARATOR '') AS '领导关怀地区'
FROM employees;

MySQL拼接字符串函数GROUP_CONCAT详解

这关怀到位了吧,你品,你细品!!!

领导的关怀能力也有限,拼接的字符串默认的最大长度是1024个字符,可以通过下面语句查看当前限制是多少:


show variables like 'group_concat_max_len';

MySQL拼接字符串函数GROUP_CONCAT详解

领导的能力可是飘忽不定的,所以我们可以灵活的设置这个值


SET [GLOBAL | SESSION] group_concat_max_len = val;

SESSION: 在当前对话中生效 GLOBAL:全局都生效

该语句在执行后,MySQL重启之前一直有作用,一旦重启 MySQL,则会恢复默认值

有时候 GROUP_CONCAT() 还要搭配 CONCAT_WS() 发挥出一点点威力,举个简单的例子

将消费者的名和姓用逗号进行分隔,然后再用 ; 进行分隔

SELECT
 GROUP_CONCAT(
   CONCAT_WS(', ', contactLastName, contactFirstName)
   SEPARATOR ';')
FROM
 customers;

这里是 CONCAT_WS()函数用法, 很简单,请自行查看吧......

注意⚠️

GROUP_CONCAT()函数返回单个字符串,而不是值列表。这意味着我们不能在 IN 运算符中使用GROUP_CONCAT()函数的结果,例如,在子查询中, 像这样:


SELECT
 id, name
FROM
 table_name
WHERE
 id IN GROUP_CONCAT(id);

总结

在许多情况下,我们都可以应用GROUP_CONCAT()函数产生出有用的结果,同时也可以结合其他函数发挥出更大的威力. 单招学会了,就要学会连招 combo 了

来源:https://segmentfault.com/a/1190000021680731

标签:MySQL,GROUP,CONCAT
0
投稿

猜你喜欢

  • 语义化的HTML结构到底有何好处?

    2009-07-13 12:38:00
  • Django框架自定义session处理操作示例

    2022-02-11 02:56:19
  • Python 可视化matplotlib模块基础知识

    2021-09-09 05:17:45
  • python访问系统环境变量的方法

    2023-06-16 00:30:39
  • Windows安装MySQL8.0.16 的步骤及出现错误问题解决方法

    2024-01-25 06:27:36
  • SQLServer 2005 列所有存储过程的语句

    2024-01-18 12:02:34
  • python可视化分析的实现(matplotlib、seaborn、ggplot2)

    2021-10-20 13:59:21
  • 你知道mysql哪些查询情况不走索引吗

    2024-01-15 06:32:00
  • python opencv将图片转为灰度图的方法示例

    2021-03-24 22:22:54
  • php中去除所有js,html,css代码

    2023-07-08 07:59:52
  • Python基础之变量的相关知识总结

    2021-05-09 00:16:06
  • Python测试Kafka集群(pykafka)实例

    2023-05-05 20:57:56
  • js中eval()函数和trim()去掉字符串左右空格应用

    2024-04-19 10:00:16
  • JavaScript对象的property属性详解

    2024-05-05 09:22:57
  • python实现二叉排序树

    2022-08-26 04:34:37
  • Python button选取本地图片并显示的实例

    2023-10-06 15:56:32
  • 如何使用Vue3设计实现一个Model组件浅析

    2024-04-27 15:57:19
  • 使用C#配合ArcGIS Engine进行地理信息系统开发

    2023-06-25 16:35:01
  • Mysql IO 内存方面的优化

    2024-01-15 11:55:18
  • 基于Python中random.sample()的替代方案

    2021-01-16 18:41:07
  • asp之家 网络编程 m.aspxhome.com