前言
今天实施找我提了一个关于时间的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真的好强大,只要心还在跳,就要努力学习,各位加油呦!