util.Date插入数据库有时差

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/engerla/article/details/89926943

问题描述

比如在java代码里面插入的时间是:2019-05-07 17:29:56
但是在数据库里面显示的时间却是:2019-05-07 09:29:56

原因

因为时区设置的问题。
UTC代表的是全球标准时间 ,但是我们使用的时间是北京时区也就是东八区,领先UTC八个小时。
UTC + (+0800) = 本地(北京)时间

解决方案

//设置为北京时间
serverTimezone=GMT%2B8 
//使用上海时间
serverTimezone=Asia/Shanghai

没有什么是一张截图解释不清楚的(如果有那就多放几张):
在这里插入图片描述

补充

GMT(格林尼治平时)

格林尼治平时(又称格林尼治平均时间或格林尼治标准时间,旧译格林威治标准时间;英语:Greenwich Mean Time,GMT)是指位于英国伦敦郊区的皇家格林尼治天文台的标准时间,因为本初子午线被定义在通过那里的经线。

理论上来说,格林尼治标准时间的正午是指当太阳横穿格林尼治子午线时(也就是在格林尼治上空最高点时)的时间。由于地球在它的椭圆轨道里的运动速度不均匀,这个时刻可能与实际的太阳时有误差,最大误差达16分钟。

由于地球每天的自转是有些不规则的,而且正在缓慢减速,因此格林尼治时间已经不再被作为标准时间使用。现在的标准时间,是由原子钟报时的协调世界时(UTC)。

UTC(世界标准时间)

协调世界时,又称世界标准时间或世界协调时间,简称UTC(从英文“Coordinated Universal Time”/法文“Temps Universel Coordonné”而来),是最主要的世界时间标准,其以原子时秒长为基础,在时刻上尽量接近于格林尼治标准时间。

猜你喜欢

转载自blog.csdn.net/engerla/article/details/89926943
今日推荐