大家好,又见面了,我是全栈君。
怕什么真理无穷,进一步有近一步的欢喜
本文分享一篇在工作遇到的一个问题,关于MySQL GROUP_CONCAT函数导致的问题。希望能帮忙到你。
开头聊几句
一年又一年,2020这一年眼看就要结束了,真是逝者如斯夫,不舍昼夜。
工作和生活都需要更多的责任和担当了,一年一年慢慢的发生变化。
业务场景
在说遇到的坑之前,先描述一下大致的业务场景。系统有一个排班的功能,一个医生一天可以排多种业务类型的排班,并且每一种业务类型的排班都支持排个多时段(时段的最小单位是15分钟)。
举例:
D医生在 2020-12-31 的 8:00~10:00、10:30~12:00 排班了【在线A】 和 【在线B】业务。
【在线A】 2020-12-31 8:00~10:00
【在线A】 2020-12-31 10:30~12:00
【在线B】 2020-12-31 8:00~10:00
【在线B】 2020-12-31 10:30~12:00
在查询这个一天排班的数据,伪SQL方便理解:
SELECT
dt,
biz_type,
GROUP_CONCAT(
CONCAT_WS('|', id, start_time, end_time)
) AS multiPeriodDetail
FROM
doctor_schedule_detail
WHERE
doctor_id = '456231'
AND dt = '2020-12-30'
GROUP BY
doctor_id,
biz_type,
dt
CONCAT_WS(‘|’, id, start_time, end_time)中的字段说明:
-
id:时段的id
-
start_time:时段开始时间
-
end_time:时段结束时间
对数据进行分组后,使用 CONCAT_WS
函数 指定分隔符进行参数拼接。然后使用 GROUP_CONCAT
函数 返回分组中字符串结果组合连接的值,默认缺省为一个逗号 (“,”)进行分隔,这个缺省值可以去掉,本例子中使用默认缺省值。
查询后结果展示如下:
至此场景描述结束。
遇到的坑
这个代码在线上已经运行很长了,有一天用户反馈说给D医生排班了,但是界面查不到这个时段的排班数据。
经过”紧张激烈”的排查,终于找到了这个问题的罪魁祸首。
如上场景描述,在查询SQL中使用了 GROUP_CONCAT
函数,在业务中因为排班的最小时段为:单位是15分钟。正常医生不会拍很多很细的班,但在特殊的场景中,有一些医生就是15分钟排一次班,而且系统中真实的 CONCAT_WS
函数拼接返回的字段比较多,那么导致查询出来的数据非常多, GROUP_CONCAT
函数就就大于默认值得数据丢弃了。
注:GROUP_CONCAT 对应的配置参数 group_concat_max_len
默认设置最大的长度 1024字节
。
查询 group_concat_max_len
配置:
show variables like "group_concat_max_len";
tips:字段内容字节长度
MySQL utf-8 编码集, 一个中文占3个字节。
-- 字符长度 输出结果:6
SELECT CHAR_LENGTH("你好2021")
-- 字节长度 输出结果:10
SELECT LENGTH("你好2021")
解决方案
在知道问题原因后,就有了对应的解决方案。
第一种方案:修改Mysql的配置,调整 group_concat_max_len
的值。
方法一:在MySQL的配置文件中加入如下配置(推荐):
group_concat_max_len = 102400
方法二:更简单的操作方法,执行SQL语句:
SET GLOBAL group_concat_max_len = 102400;
SET SESSION group_concat_max_len = 102400;
生产环境,肯定要用方法一:在MySQL的配置文件。但考虑生产环境修改配置需要走一些流程和审批,于是有了第二种方案的考虑。
第二种方案:进行业务功能的调整,需求的调整或者GROUP_CONCAT
拼接少返回一些数据
功能已经上线,此时在修改,对业务有一定的影响
综合考虑后,决定更改group_concat_max_len的值,经过对业务的分析计算出具体要更改的值。
结语
在真实场景中,大多数问题的解决方案不止一种,在权衡后找到一个符合当时的问题的最优解决方案。
See you next good day~
Java编程技术乐园:分享干货技术,每天进步一点点,小的积累,带来大的改变。后台回复【秘籍】获取精选资料
文章推荐
用MySQL 执行计划分析 DATE_FORMAT 函数对索引的影响
谢谢你的阅读,愿你有所收获,也欢迎留言一起讨论
如果觉得本文对你有所帮助,欢迎转发。您的点赞和转发,就是对我最大的鼓励!
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/120961.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...