mysql group_concat()方法慎用,有长度限制

mysql group_concat()方法超过规定长度会截断字符串,导致查询结果不完整

比如:

select type,group_concat(name) name from s_type
where 1 = 1
and p_name in
<foreach collection="nameArray" index="index" item="item" close=")" open="(" separator=",">
      #{item}
</foreach>
group by type

查询结果列中的name结果可能不完整,导致后续程序出错,这种错误不易发现和排查。

所以group_concat()要慎用!!!


查询group_concat()函数的长度限制:

 show variables like 'group_concat_max_len';

我的数据库默认是1024个字符长度(使用数据库-mysql):

参考https://blog.csdn.net/haijiege/article/details/77867279

网上有两种做法,一种是修改my.ini配置,添加

group_concat_max_len = 4096   

group_concat_max_len = -1  # -1为最大值或填入你要的最大长度

看网上的说法都是需要重启mysql服务,设置才生效。本人还没实际验证。

我采用的修改方式是直接不使用group_concat方法,涉及的业务模块不多,而且不影响其他业务逻辑,并且数据库没有重启的权限。


又是在bug上写代码的一天,程序员的生活就是这么朴实无华!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值