技术分享 数据库 MYSQL 查看内容

GROUP_CONCAT()函数最大长度限制

老高 | 发布于 2019-11-26 10:12| 浏览()| 评论() | 收藏() | 点赞() | 打印

摘要: MySQL提供的group_concat函数可以拼接某个字段值成字符串,如 select group_concat(user_name) from sys_user,默认的分隔符是 逗号,即"," ,如果需要自定义分隔符可以使用 SEPARATOR

MySQL提供的group_concat函数可以拼接某个字段值成字符串,如 select group_concat(user_name) from sys_user,默认的分隔符是 逗号,即"," ,如果需要自定义分隔符可以使用 SEPARATOR

如:select group_concat(user_name SEPARATOR '_')  from sys_user

但是如果 user_name  拼接的字符串的长度字节超过1024 则会被截断。

通过命令 "show variables like 'group_concat_max_len' " 来查看group_concat 默认的长度:

操作方法:

(1)在MySQL配置文件中加入:

group_concat_max_len = 102400

(2)更简单的操作方法,执行SQL语句:

SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;

注意:该方法缺点是重启服务后设置失效


发表评论(对文章涉及的知识点还有疑问,可以在这里留言,老高看到后会及时回复的。)

表情