【经验】java时区问题

首先得有一个预备知识

时间戳:指1970-01-01 00:00:00(GMT/UTC)起到当前的毫秒数。与时区无关,不同时区同一个时刻的时间戳是相同的。所以,时间戳不受时区影响。但是,不同时区的国家同一个时间戳显示的日期不同,所以同一时刻的时间戳表示的日期会受时区影响。

一、MySQL数据库连接时区问题

1.jdbc连接时设置serverTimezone。

由于后台生成properties文件jdbc连接并没有区分国内外服务器时区,统一用的中国时区Asia/Shanghai,所以库timestamp类型字段都显示成了国内的时间。

解决办法:如果项目并没有上线,则可以使用JDK的默认时区,设置serverTimezone为JDK的默认时区

java 复制代码
ZoneId.systemDefault();

也是系统的时区,这样保证了数据库timestamp字段日期跟系统保持一致;如果项目上线后,则不能修改,保持不变。修改后后会影响原来的涉及日期的逻辑。 如果有操作系统时区会更变的情况下,需要程序监听时区的变化。重设默认时区。

2.jdbc连接时不设置serverTimezone。

会有JDK,MySQL关于CST标准冲突导致的时区问题。

当未设置serverTimezone时,数据库将连接使用MySQL服务端的time_zone(全局时区),默认值为CST。time_zone的默认值为SYSTEM,而SYSTEM取的是system_time_zone(系统时区)的值,system_time_zone的默认值就是CST。

MySQL中,CST表示的是:中国标准时间(UTC+08:00)。

JDK中,CST表示的是:美国标准时间(UTC-05:00或UTC-06:00)。

由于JDK和MySQL服务端对CST时区的不同标准(可能是下载的地址版本不同),会导致时间问题。

解决办法:jdbc连接时设置serverTimezone。

二、夏冬令时变化导致的时区问题

在程序中,如果涉及天数的计算,需要根据实际情况选择不同的计算规则。如果要用日期,则全部用日期为标准计算;如果要用时间戳,则全部用时间戳为标准计算。检查使用的每一个时间工具,计算是用的日期还是时间戳。否则会由于夏冬令时的变化导致时区问题。

比如,在hutool工具中,DateUtil工具中offsetDay方法,计算偏移30天后的日期,是根据时区为标准获得的日期。如果初始日期是冬令时某天的零点,偏移天数后的日期是夏令时某天的零点,但是由于转变为夏冬令时会让日期直接快/慢一个小时,导致前后的时间在当前时区的时间戳,跟以时间戳为标准计算天数的betweenDay方法,计算出来的天数不同。

相关推荐
南城花随雪。几秒前
Spring框架之装饰者模式 (Decorator Pattern)
java·开发语言·装饰器模式
编程、小哥哥4 分钟前
设计模式之装饰器模式(SSO单点登录功能扩展,增加拦截用户访问方法范围场景)
java·设计模式·装饰器模式
究极无敌暴龙战神X6 分钟前
前端学习之ES6+
开发语言·javascript·ecmascript
虞书欣的611 分钟前
Python小游戏24——小恐龙躲避游戏
开发语言·python·游戏·小程序·pygame
FHYAAAX19 分钟前
【机器学习】任务十:从函数分析到机器学习应用与BP神经网络
开发语言·python
汉克老师37 分钟前
GESP4级考试语法知识(贪心算法(四))
开发语言·c++·算法·贪心算法·图论·1024程序员节
爱吃生蚝的于勒1 小时前
C语言最简单的扫雷实现(解析加原码)
c语言·开发语言·学习·计算机网络·算法·游戏程序·关卡设计
Ai 编码助手1 小时前
Go语言 实现将中文转化为拼音
开发语言·后端·golang
hummhumm1 小时前
第 12 章 - Go语言 方法
java·开发语言·javascript·后端·python·sql·golang
hummhumm1 小时前
第 8 章 - Go语言 数组与切片
java·开发语言·javascript·python·sql·golang·database