SpringBoot中Mybatis时区问题

最近遇到一个巨坑的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

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

总结

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

想学习分布式、微服务、JVM、多线程、架构、java、python的童鞋,千万不要扫码,否则后果自负~

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

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值