首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >MySQL字段拼接的三个函数

MySQL字段拼接的三个函数

作者头像
bisal
发布2023-05-10 09:13:53
发布2023-05-10 09:13:53
2.5K00
代码可运行
举报
运行总次数:0
代码可运行

MySQL中如果对字段有拼接需求,可以利用原生提供的三个函数,功能虽然相近,但细节略有不同,针对不同的场景,选择不同的方案,

  • concat()
  • concat_ws()
  • group_concat()

1. concat()函数

可以实现多个字段使用空字符串拼接为一个字段,如下所示,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select concat(id, type) from mm_content limit 10;
+------------------+
| concat(id, type) |
+------------------+
| 100818image   |
| 100824image   |
| 100825video   |
| 100826video   |
| 100827video   |
| 100828video   |
| 100829video   |
| 100830video   |
| 100831video   |
| 100832video   |
+------------------+
10 rows in set (0.00 sec)

但是,如果有字段值为NULL,则结果为NULL,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select concat(id, type, tags) from mm_content limit 10;
+------------------------+
| concat(id, type, tags) |
+------------------------+
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
| NULL          |
+------------------------+
10 rows in set (0.00 sec)

2. concat_ws()函数

concat()函数如果想要使用分隔符分割,就需要每个字段中间插一个字符串,不是非常便捷,但是通过concat_ws()函数可以一次性地解决分隔符的问题,并且不会因为某个值为NULL,而全部为NULL,如下所示,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select concat_ws(' ', id, type, tags) from mm_content limit 10;
+--------------------------------+
| concat_ws(' ', id, type, tags) |
+--------------------------------+
| 100818 image          |
| 100824 image          |
| 100825 video          |
| 100826 video          |
| 100827 video          |
| 100828 video          |
| 100829 video          |
| 100830 video          |
| 100831 video          |
| 100832 video          |
+--------------------------------+
10 rows in set (0.00 sec)

3. group_concat()函数

正常情况下,这个语句会报错,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select id from test_user group by age;
ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'test_user.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

但是group_concat()函数可以将分组状态下的其他字段拼接成字符串查询,如下所示,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select group_concat(name) from test_user group by age;
+--------------------+
| group_concat(name) |
+--------------------+
| wen,ning           |
| wxnacy,win         |
+--------------------+
2 rows in set (0.00 sec)

默认使用逗号分隔,我们也可以指定分隔符,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select group_concat(name separator ' ') from test_user group by age;
+----------------------------------+
| group_concat(name separator ' ') |
+----------------------------------+
| wen ning                         |
| wxnacy win                       |
+----------------------------------+
2 rows in set (0.00 sec)

还可以将字符串按照某个顺序排列,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select group_concat(name order by id desc separator ' ') from test_user group by age;
+---------------------------------------------------+
| group_concat(name order by id desc separator ' ') |
+---------------------------------------------------+
| ning wen                                          |
| win wxnacy                                        |
+---------------------------------------------------+
2 rows in set (0.00 sec)

如果想要拼接多个字段,默认是用空字符串进行拼接的,我们可以利用concat_ws()方法嵌套一层,

代码语言:javascript
代码运行次数:0
运行
复制
mysql> select group_concat(concat_ws(',', id, name) separator ' ') from test_user group by age;
+------------------------------------------------------+
| group_concat(concat_ws(',', id, name) separator ' ') |
+------------------------------------------------------+
| 1,wen 2,ning                                         |
| 3,wxnacy 4,win                                       |
+------------------------------------------------------+
2 rows in set (0.00 sec)

针对不同的场景,可以选择不同的字符串拼接函数,满足个性化需求,因此,平时积累一些常用的函数,还是有作用的。

参考链接,

https://www.zhuxianfei.com/database/mysql/43287.html

如果您认为这篇文章有些帮助,还请不吝点下文章末尾的"点赞"和"在看",或者直接转发pyq,

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-05-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档