mybatis插入的数据神秘消失,原因竟然是。。。

image

最近遇到一个巨坑的bug,mybatis打印出来sql日志显示数据入库成功,但是数据库查询却怎么也查询不到数据,debug日志打了一堆,硬是没发现任何问题。

问题背景

这边先给大家介绍一下bug背景,有一个订单服务需要实时获取第三方接口订单数据,然后对第三方的json数据进行解析入库。流程其实很简单,但是数据库就是没有当天的订单数据,代码检查了好几遍都没发现问题。

问题分析

对于这种现象,出问题的地方一般有以下几个地方:

  1. 第三方订单数据获取失败
  2. 第三方订单数据确实没有今日订单数据
  3. 程序执行到mybatis入库的时候出现异常
  4. 因为代码问题,导致入库数据出现异常

异常排查

针对上述可能出现的问题,博主也一一进行了排查,发现今日订单数据存在且数据正常,执行期间没有任何异常,控制台也成功打印出sql日志,sql语法和参数也都没有任何问题,一一排查完,发现都不是这些问题的时候,真的是好绝望啊。。。

深入思考

后面针对上述现象,博主仔细的思考了一下,如果控制台都打印出sql日志了,那数据库插入操作肯定是没问题的,那会不会是数据插入的数据出问题了,给插入到其它日期的订单数据中了呢,用订单id一查,发现真的是插入日期出现问题,导致今日订单全无,都往前了一天。

解决问题

最后查资料才发现,竟然是mybatis本身的问题,mybatis在插入date类型数据的时候,会有时区问题。例如2019-06-15插入到数据库中会变成2019-06-14,这也是导致插入数据消失的罪魁祸首。

要解决这个问题其实很简单,修改application.properties中的
mybatisspring.datasource.url=jdbc:mysql://127.0.0.1:3306/xuanyi?useUnicode=true&characterEncoding=utf8后面增加&serverTimezone=GMT%2B8

1
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xuanyi?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8

总结

解决问题很解决,难的是怎么去发现问题。特别是这种会导致数据异常的bug,最为致命,大家上线之前一定要做好充分的测试,否则还真有可能发生删库跑路的事情~

林老师带你学编程https://wolzq.com

林老师带你学编程 wechat
欢迎您扫一扫上面的微信公众号,订阅我的博客!