最近遇到一个巨坑的bug,mybatis打印出来sql日志显示数据入库成功,但是数据库查询却怎么也查询不到数据,debug日志打了一堆,硬是没发现任何问题。
这边先给大家介绍一下bug背景,有一个订单服务需要实时获取第三方接口订单数据,然后对第三方的json数据进行解析入库。流程其实很简单,但是数据库就是没有当天的订单数据,代码检查了好几遍都没发现问题。
对于这种现象,出问题的地方一般有以下几个地方:
针对上述可能出现的问题,博主也一一进行了排查,发现今日订单数据存在且数据正常,执行期间没有任何异常,控制台也成功打印出sql日志,sql语法和参数也都没有任何问题,一一排查完,发现都不是这些问题的时候,真的是好绝望啊。。。
后面针对上述现象,博主仔细的思考了一下,如果控制台都打印出sql日志了,那数据库插入操作肯定是没问题的,那会不会是数据插入的数据出问题了,给插入到其它日期的订单数据中了呢,用订单id一查,发现真的是插入日期出现问题,导致今日订单全无,都往前了一天。
最后查资料才发现,竟然是mybatis本身的问题,mybatis在插入date类型数据的时候,会有时区问题。例如2019-06-15插入到数据库中会变成2019-06-14,这也是导致插入数据消失的罪魁祸首。
要解决这个问题其实很简单,修改application.properties中的 mybatis的spring.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,最为致命,大家上线之前一定要做好充分的测试,否则还真有可能发生删库跑路的事情~
林老师带你学编程:https://wolzq.com
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有