Mysql存储过程的递归调用及数据量过大group_concat()显示不全的问题

业务场景

使用mysql group_concat()函数,对查询的数据进行字符串连接操作。
由于查询的结果较多,连接后的结果很长导致不能完全显示。

第一种解决方案(不需要重启Mysql, 如果mysql重启后设置会失效,需重新设置)

执行SHOW VARIABLES LIKE 'group_concat_max_len'查看当前GROUP_CONCAT的最大长度,

Mysql存储过程的递归调用及数据量过大group_concat()显示不全的问题_第1张图片

执行:

SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;
此种方式在mysql重启后会读取配置文件重新设置,会导致设置失效,所以建议依旧要修改配置文件

第二种解决方案(需重启Mysql)

修改配置文件:my.ini
在[mysqld]下新增配置:group_concat_max_len = 102400

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

设置后,重启MySQL

你可能感兴趣的:(sql,数据库)