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

相关文章

优化MySQL数据库发布系统存储的方法有:1.mysql库主从读写分...
使用mysql的方法:在“我的电脑”→右键→“管理”→“服务”...
在mysql中查看root用户权限的方法:1.命令行启动mysql服务;...
MySQL主从复制是用来备份一个与主数据库一样环境的从数据库,...
运行mysql的方法1.启动mysql服务,在“我的电脑”→右键→“...
开启mysql的方法1.可以通过快捷键win+r,输入cmd,打开窗口,...