MySQL修改时区

Posted leon-a

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL修改时区相关的知识,希望对你有一定的参考价值。

以下记录修改mysql时区的几种方法。

具体:
方法一:通过mysql命令行模式下动态修改
1.1 查看mysql当前时间,当前时区

> select curtime();   #或select now()也可以
+-----------+
| curtime() |
+-----------+
| 15:18:10  |
+-----------+

> show variables like "%time_zone%";
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | CST    |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)
#time_zone说明mysql使用system的时区,system_time_zone说明system使用CST时区

 
1.2 修改时区

> set global time_zone = ‘+8:00‘;  ##修改mysql全局时区为北京时间,即我们所在的东8区
> set time_zone = ‘+8:00‘;  ##修改当前会话时区
> flush privileges;  #立即生效

 
方法二:通过修改my.cnf配置文件来修改时区

# vim /etc/my.cnf  ##在[mysqld]区域中加上
default-time_zone = ‘+8:00‘

# /etc/init.d/mysqld restart  ##重启mysql使新时区生效

 
方法三:如果不方便重启mysql,又想临时解决时区问题,可以通过java或其他语言在初始化mysql时初始化mysql时区
这里,以java为例,在指定jdbc url为 jdbc:mysql://61.50.111.214:56723/pre?serverTimezone=GMT%2B8。

这样可以在保证你不重启的情况下改变时区。但是mysql的某些系统函数还是不能用如:now()。

 

以上是关于MySQL修改时区的主要内容,如果未能解决你的问题,请参考以下文章

mysql修改和查看时区(十五)

如何修改mysql url链接指定时区

MySQL修改时区

MySQL中修改时区

修改MySQL时区

MySQL修改数据库时区