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

  

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

问题

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

使用显示变量如“% group_concat_max_len %“查看

 mysql>显示变量如“% group_concat_max_len %“;
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | Variable_name,,,| |值
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | group_concat_max_len | 1024 |
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  1行集(0.00秒)
  
  mysql> 

1临时修改(命令行)

1.1修改group_concat_max_len长度为:10240

 mysql>集全球group_concat_max_len=10240;
  mysql>设置会话group_concat_max_len=10240; 

1.2查看

 mysql>显示变量如“% group_concat_max_len %“;
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | Variable_name,,,| |值
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | group_concat_max_len | 10240 |
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  1行集(0.00秒)
  
  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服务不重启的话,可以配合临时修改一起使用

<>以前美元服务mysqld重启

2.3查看

 mysql>显示变量如“% group_concat_max_len %“;
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | Variable_name,,,| |值
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  | group_concat_max_len | 10240 |
  + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + +
  1行集(0.00秒)
  
  mysql> 

3附加

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

此种情况下group_concat_max_len为4294967295

注:4294967295=2 ^ 32,- 1

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

<强>

  

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