微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

mysql多条记录的某个字段拼接成一个字段方法

本文主要给大家简单讲讲mysql多条记录的某个字段拼接成一个字段方法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MysqL多条记录的某个字段拼接成一个字段方法这篇文章可以给大家带来一些实际帮助。

问题

GROUP_CONCAT函数用于将多个字符串连接成一个字符串,在拼接成字符串时就会存在拼接长度的问题,MysqL 认的拼接最大长度为1024 个字节,由于1024个字节会出现不够用的情况,所以有时需要去根据情况进行修改

使用SHOW VARIABLES LIKE "%group_concat_max_len%"查看

MysqL> SHOW VARIABLES LIKE "%group_concat_max_len%";
+----------------------+-------+
| Variable_name        | Value |
+----------------------+-------+
| group_concat_max_len | 1024  |
+----------------------+-------+
1 row in set (0.00 sec)

MysqL>

1 临时修改(命令行)

1.1 修改group_concat_max_len长度为:10240

MysqL> SET GLOBAL group_concat_max_len = 10240;
MysqL> SET SESSION group_concat_max_len = 10240;

1.2 查看

MysqL> SHOW VARIABLES LIKE "%group_concat_max_len%";
+----------------------+-------+
| Variable_name        | Value |
+----------------------+-------+
| group_concat_max_len | 10240  |
+----------------------+-------+
1 row in set (0.00 sec)

MysqL>

2 永久修改配置文件

2.1 修改配置文件:my.cnf

在[MysqLd]下新增配置:group_concat_max_len = 10240

$ vim /etc/my.cnf
......
[MysqLd]
......
group_concat_max_len = 10240  #添加

2.2 重启MysqL服务

如果MysqL服务不重启的话,可以配合临时修改一起使用

$ service MysqLd restart

2.3 查看

MysqL> SHOW VARIABLES LIKE "%group_concat_max_len%";
+----------------------+-------+
| Variable_name        | Value |
+----------------------+-------+
| group_concat_max_len | 10240  |
+----------------------+-------+
1 row in set (0.00 sec)

MysqL>

3 附加

有时我们并不知需要多大的字节才能满足需求,此种情况可以考虑不设置最大字节(即采用最大字节数)即在配置文件设置group_concat_max_len=-1

此种情况下group_concat_max_len为4294967295

注: 4294967295 = 2^32  - 1

MysqL多条记录的某个字段拼接成一个字段方法就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐