三思而折腾 发表于 2024-11-26 10:02:58

mysql函数group_concat()返回结果不全问题

一、场景

mysql使用group_concat()函数拼接返回字段时
发现返回结果数据不全

二、原因

是group_concat()函数返回结果的字符数大于mysql参数group_concat_max_len配置的最大字符长度

三、排查


查看group_concat_max_len配置

SHOW VARIABLES LIKE 'group_concat_max_len'发现配置的字符长度只有4,确实太少


修改group_concat_max_len配置

a) 如果不方便重启mysql,可以通过以下命令进行配置修改
SET GLOBAL group_concat_max_len = 102400修改后再次通过命令进行查看

注:

[*]如果不是通过命令窗口进行操作
[*]而是通过Navicat Premium、SQLyog等软件进行配置的修改
[*]需要打开一个新的查询页面
[*]执行SHOW VARIABLES LIKE 'group_concat_max_len'才能查询到最新的配置值
注:

[*]以上方式在mysql重启后会读取配置文件重新设置
[*]会导致设置失效
b) 修改mysql配置文件,永久生效
修改mysql配置文件:my.ini或者my.cnf
注:

[*]到底是修改my.ini还是my.cnf具体看mysql用的是哪个
[*]根据实际情况选择
[*]一般两者只会存在一个

在下新增以下配置
group_concat_max_len = 102400
保存后重启mysql服务

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

来源:https://www.jb51.net/database/330780te6.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: mysql函数group_concat()返回结果不全问题