今天无意间发现,自己写的一个小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,我就没去测试了,应该也是可行的