前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot中Mybatis时区问题

SpringBoot中Mybatis时区问题

作者头像
林老师带你学编程
发布2019-07-02 10:29:06
2.8K0
发布2019-07-02 10:29:06
举报
文章被收录于专栏:强仔仔强仔仔

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

代码语言:javascript
复制
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xuanyi?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT%2B8

总结

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

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年06月15日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题背景
  • 问题分析
  • 异常排查
  • 深入思考
  • 解决问题
  • 总结
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档