关于数据库与服务器时区的问题

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

一、概述

  最近在做MySql生日提交的时候,通过URL访问数据库得到的数据总是比数据库中保存的数据少一天。查阅资料找到以下解决方法,用以记录备忘。

二、修改MySql数据库的默认时区

  MySql数据库创建后,默认的时区比东八区少了八个小时。如果Sql语句中使用到MySql的时间的话就会比正常时间少了八个小时。所以需要修改MySql的系统时区,使其显示的时间和我们现在的时间一致。
  1)查看mysql系统时间

select now(); 

  2)设置时区更改为东八区

set global time_zone = '+8:00';

  3)刷新权限

flush privileges; 

  4)退出后重新登录,即可。

三、修改数据库的驱动

  若时间还是不对,有可能是驱动的问题,检查下驱动信息,如果连接参数中的字段serverTimezone设置为UTC,将UTC更改为 Asia/Shanghai就可以了。

jdbc:mysql://127.0.0.1:3306/test?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=Asia/Shanghai

四、查看和修改Linux服务器上的时区

  对于部署在海外的Linux服务器来说,拿到的机器时区和本地并不一样,导致运行在上面的应用也面临时区问题,所以有必要修改Linux服务器上的时区。
  1、查看服务器当前的时区
  查看当前生效的时区,可以通过date -R命令来查看当前时间。

[webadmin@host ~]$ sudo date -R
Sun, 19 Aug 2018 15:18:38 +0800

  注:+0800,即东8区。
  2、设置时区
  1)通过tzselect命令查看时区向导
  tzselect命令看起来很像一个时区选择的工具,但并非如此。事实上tzselect仅仅是一个查看时区表示方式的『向导』程序而已。通过依次询问大洲→国家→城市,最后告诉你如何TZ变量的写法,比如北京时间是:Asia/Shanghai。
  2)通过修改*TZ变量,直接修改时区信息*
  可以通过修改TZ变量,直接修改时区信息,比如:

[webadmin@host ~]$ sudo date -R
Sun, 19 Aug 2018 15:25:15 +0800
[webadmin@host ~]$ sudo export  TZ='Asia/Shanghai'
[webadmin@host ~]$ sudo date -R              
Sun, 19 Aug 2018 15:25:51 +0800

  有Linux经验的小伙伴都知道,不写在文件里的设置更改很难生效一般是会话级的,重新登录会消失。所以,这样直接修改TZ的尿性绝对做不到持久化更改时区的。
  正确的方式是到/etc/profile里(或用户的.profile或.bashrc文件),直接export TZ变量为要更改的时区(时区的名字可以用tzselect向导来确定)。
  3)重启相关service或者直接重启服务器
  4)通过/etc/localtime文件修改时区
  默认情况下情况下,TZ属性是空,这时候是靠/etc/localtime文件来确定的时区。而此文件通常又是一个到/usr/share/zoneinfo/下各种时区文件的软连接。通过修改/etc/localtime指向的软连接,进而修改系统的时区。比如下面的方法,将localtime文件设置为了北京时间:
 

 ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

四、参考文章

  Linux查看和修改时区

猜你喜欢

转载自blog.csdn.net/vae1314chuanchen/article/details/81838476