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

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

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

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

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

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

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

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

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

我又去查了下本地mysql

果然不同,这里没有CST

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

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

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

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

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

测试,问题解决.

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

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

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

把SYSTEM改成+13:00

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

红烧柯基

感谢您的支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值