背景
问题描述
在MySQL数据表中,存在一个JSON结构的扩展字段,通过updateById进行更新写入操作。更新写入的同一个字段名出现了混合使用了驼峰命名和下划线命名两种格式。
ps: FastJson版本是1.2.83
问题影响
数仓同学离线统计数据时发现字段名有两种定义,产生了迷惑,不清楚如何统计;对线上实时链路还无任何影响。
原因定位
- 首先例行公事,先检查多机房部署的代码版本是否一致,类似数据是否有持续写入
- 检查过后发现,多区代码部署版本完全一致;
- 且数据字段命名驼峰&下划线同时存在的数据持续有写入;
- 检查下代码中是否有不同的写入位置,且写入的字段定义规则不一致
- 发现这个字段只有一处更新写入,且通过业务日志看这个字段没有任何问题;
- 尝试测试环境复现
- 首先检查了下测试环境是否存在类似数据,发现并没有;
- 其次在测试环境尝试构造请求写入,并未复现;
- 到了常规猜测环节
- 首相想到的是否有配置了全局的fastjson序列化驼峰下划线转换配置
- 发现确实是有配置的,全局配置成了驼峰格式转换为下划线;配置如下:
- 首相想到的是否有配置了全局的fastjson序列化驼峰下划线转换配置
@Configuration
public class FastJsonConfig {
@Bean
public SerializeConfig serializeConfig(){
SerializeConfig serializeConfig = SerializeConfig.getGlobalInstance();
serializeConfig.propertyNamingStrategy = PropertyNamingStrategy.SnakeCase;
return serializeConfig;
}
}
- 那么新的问题来了,配置了全局转换为下划线的情况呢?
首先在mybatis Xxx.xml 中的update语句里有
<if test="extraInfo != null"