查询Mysql库中的时间比正常时间少1小时

博客讲述了在处理时间显示Bug时,发现与夏令时有关。1987年的日期在页面显示比数据库中少1小时,经过排查,发现香港时区在1986-1991年间实行夏令时,调整项目时区后问题解决。这体现了对时间处理和历史规则理解的重要性。
摘要由CSDN通过智能技术生成

夏令时

前言

今天实施找我提了一个关于时间的Bug,联系人的出生日期设置的为1987-06-02 00:00:00年,但是页面展示却是1987-06-01 23:00:00,少了1小时,本以为是个小问题,结果项目组讨论了半个小时。

正文

其实对于数据库缺少8小时大家都很常见,肯定是因为时区的问题,第一反应去连接数据库的配置文件中url是否写了serverTimezone这个参数,发现用的香港的时区,而且别人的日期是没有问题的,就不是它的问题。
在这里插入图片描述
然后去排查数据库是不是设置了时间,查看数据库时区。发现DBA设置了好了时区,在基础上+08:00,所以排除了时区的问题。

show variables like'%time_zone';

在这里插入图片描述
然后发现数据库里是正常的1987-06-02,但是页面就是1987-06-01 23:00:00,而且我们发现这个bug和时间的区间有关1995年的就没问题。
请教项目组大佬,大哥也感觉很神奇,上报技术经理,经理也一头雾水,最后我们不考虑项目,只考虑一小时问题,查到关于夏令时的事。
夏令时:从1986年到1991年的六个年度,每年从四月中旬第一个星期日的凌晨2时整(北京时间),将时钟拨快一小时,即将表针由2时拨至3时,夏令时开始;到九月中旬第一个星期日的凌晨2时整(北京夏令时),再将时钟拨回一小时,即将表针由2时拨至1时,夏令时结束。(注:摘抄百度百科)
跟我们的项目问题时间刚好吻合,我们的时区采用的Hongkang,查询香港刚好执行夏令时。然后我们修改了项目时区解决问题,
在这里插入图片描述

结束

不由感叹java真的好强大,只要心还在跳,就要努力学习,各位加油呦!

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值