【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

今天无意间发现,自己写的一个小demo出现了一个很奇怪的问题,就是数据库存储的时间比实际时间慢13个小时,但是页面上查询显示出来的又是正常的,

比如我17:50存入一条数据,可是数据库居然是04:50,小了13个小时

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

但是我去查询的时候,又是正常的

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

当时第一反应有点懵,感觉很奇怪,试了几次都是这样的,用了几年的mysql,还从未遇到过这种事,想了想应该是时区的问题,

首先排除服务器时间问题,发现和本地时间一致

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

我用的是阿里云的mysql,都是默认的设置.

然后排除mysql的时间,发现也是一致的

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

然后去百度查了下,mysql的时区,真的和网上说的一样,

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

我又去查了下本地mysql

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

果然不同,这里没有CST

基本可以确定是CST的问题了,然后去百度cst

 

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

发现这个居然代表了四个时区,那怎么分别呢?

由上图可以知道美国中部时间和中国标准时间相差14个小时,非常接近相差的13个小时。因为当前是夏季,所以刚好是相差13个小时。
至此可以初步判断应该是Java将CST理解成了美国中部时间(个人猜测,不知道对不对)。

如果是这样,那就应该好解决了,我去给它设置个指定时区不就可以了.

然后我去mysql配置里面加了&serverTimezone=Asia/Shanghai

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

测试,问题解决.

还是觉得有点奇怪,为什么以前从未遇到过呢,公司也用过阿里云的mysql,难道都设置过吗?

可惜现在没有公司项目代码,只能去上班了再去看下.

另外我看网上说的还有一种方法,就是去更改,阿里云的mysql参数

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

把SYSTEM改成+13:00

【MySQL】页面上查询时间与数据库中时间相差13个小时原因及解决办法

因为修改需要重启mysql,我就没去测试了,应该也是可行的