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用的是哪个 - 根据实际情况选择
- 一般两者只会存在一个
在[mysqld]
下新增以下配置
group_concat_max_len = 102400
保存后重启mysql服务
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
mysql8.0.20安装与连接navicat的方法及注意事项
这篇文章主要介绍了mysql8.0.20安装与连接navicat的方法及注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-05-05MySql5.6使用validate password 插件加强密码强度的安装及使用方法
在mysql5.6中使用validate password插件加强密码强度,支持密码的强度要求,是一款非常好用的密码加强插件,下面小编通过本文给大家介绍MySql5.6使用validate password 插件加强密码强度的安装及使用方法,小伙伴们一起学习吧2016-07-07MySQL命令行中给表添加一个字段(字段名、是否为空、默认值)
本文介绍MySQL数据库使用SQL语句来在现有的表中,添加一个新的字段,包括设置字段的是否为空、默认值等2016-04-04MySQL报错1067 :Invalid default value for&n
在使用MySQL5.7时,还原数据库的时候报错,下面就来介绍一下MySQL报错1067 :Invalid default value for ‘字段名’,具有一定的参考价值,感兴趣的可以了解一下2024-05-05mysql 字符串长度计算实现代码(gb2312+utf8)
PHP对中文字符串的处理一直困扰于刚刚接触PHP开发的新手程序员。下面简要的剖析一下PHP对中文字符串长度的处2011-12-12
最新评论