MySQL时区查看及设置全过程

 更新时间:2025年01月22日 16:55:23   作者:AGLJC  
在服务器环境下,MySQL默认时区可能是UTC,需注意应用时区设置,若查询条件使用Now()/sysdate(),会根据MySQL时区查询,导致时间错乱,可使用`selectnow()`检查时间准确性,查看和修改MySQL时区的方法包括使用命令和修改配置文件

说明

在服务器环境下(linux 或 docker),有时系统时区默认是 UTC 时区,这时需要格外注意下应用使用的时区信息。

若查询条件中含有 Now()/sysdate(),则会按 mysql 的时区信息查询,造成时间错乱。

可以使用 select now(); 来检查 mysql 的当前时间是否准确。

查看数据库获取的当前时间语句:

select SYSDATE();
select now();

查看时区

show variables like '%time_zone%';

看到MySQL 服务器使用操作系统的时区设置,系统使用了CST时区

Time zone: Asia/Shanghai (CST, +0800):

中国标准时间:China Standard Time UT+8:00

[root@hcss-ecs-3983 ~]# timedatectl
      Local time: Sun 2024-07-28 14:43:17 CST
  Universal time: Sun 2024-07-28 06:43:17 UTC
        RTC time: Sun 2024-07-28 06:43:15
       Time zone: Asia/Shanghai (CST, +0800)
     NTP enabled: yes
NTP synchronized: yes
 RTC in local TZ: no
      DST active: n/a
[root@hcss-ecs-3983 ~]# date
Sun Jul 28 14:46:38 CST 2024

Java程序MySQL链接url配置

url: jdbc:mysql://127.0.0.1:3306/mydata?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=Asia/Shanghai

修改MySQL的时区

可以使用以下命令修改数据库的时区

SET GLOBAL time_zone = 'Asia/Shanghai';
SET time_zone = 'Asia/Shanghai';

也可以修改my.cnf配置文件修改,添加一行,重启MySQL服务生效

default-time-zone=Asia/Shanghai

docker容器使用宿主机时区

命令格式:

docker exec your_container_name ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo "Asia/Shanghai" > /etc/timezone

通过容器名去修改,示例如下:

[root@hcss-ecs-3983 ~]# history | grep timezone
 1299  2024-07-14 13:43:34 root docker exec mysql ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo "Asia/Shanghai" > /etc/timezone
 2159  2024-07-28 15:00:25 root history | grep timezone
[root@hcss-ecs-3983 ~]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED       STATUS       PORTS                                                  NAMES
577359655a60   redis:6.0.6    "docker-entrypoint.s…"   5 weeks ago   Up 2 weeks   0.0.0.0:6379->6379/tcp, :::6379->6379/tcp              myredis
920994cf01b0   mysql:8.0.30   "docker-entrypoint.s…"   7 weeks ago   Up 3 days    0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp   mysql

修改后,容器的时间:

bash-4.4# date
Sun Jul 28 15:01:50 CST 2024
bash-4.4# 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL逻辑架构与常用的存储引擎方式

    MySQL逻辑架构与常用的存储引擎方式

    这篇文章主要介绍了MySQL逻辑架构与常用的存储引擎方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • MySQL之mysqldump的使用详解

    MySQL之mysqldump的使用详解

    这篇文章主要介绍了MySQL之mysqldump的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Mysql中幻读的概念以及如何解决

    Mysql中幻读的概念以及如何解决

    这篇文章主要介绍了Mysql中幻读的概念以及如何解决,幻读指的是一个事务在前后两次查询同一个范围的时候,后一次查询看到了前一次查询没有看到的行,需要的朋友可以参考下
    2023-05-05
  • Mysql如何查看是否使用到索引

    Mysql如何查看是否使用到索引

    这篇文章主要介绍了Mysql如何查看是否使用到索引问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • MySQL查询和筛选存储的JSON数据的操作方法

    MySQL查询和筛选存储的JSON数据的操作方法

    MySQL是常用的关系型数据库管理系统,为了支持非结构化数据的存储和查询,MySQL引入了对JSON数据类型的支持,JSON是一种轻量级的数据交换格式,在现代应用程序中得到了广泛应用,处理和存储非结构化数据变得越来越重要,本文给大家介绍mysql查询JSON数据的相关知识,一起看看吧
    2024-01-01
  • MySQL日期加减函数详解

    MySQL日期加减函数详解

    在本篇文章里小编给大家分享的是关于MySQL日期加减函数用法以及实例,需要的朋友们可以参考下。
    2020-05-05
  • MySQL转换Oracle的需要注意的七个事项

    MySQL转换Oracle的需要注意的七个事项

    有很多应用项目, 刚起步的时候用MySQL数据库基本上能实现各种功能需求,随着应用用户的增多,数据量的增加,MySQL渐渐地出现不堪重负的情况:连接很慢甚至宕机,于是就有MySQL转换Oracle的需求,应用程序也要相应做一些修改。
    2010-12-12
  • MySQL约束之默认约束default与零填充约束zerofill

    MySQL约束之默认约束default与零填充约束zerofill

    这篇文章主要介绍了MySQL约束之默认约束default与零填充约束zerofill,MySQL 默认值约束用来指定某列的默认值。更多相关资料需要的朋友可以参考一下
    2022-07-07
  • 阿里云ESC 安装 MYSQL8.0的教程

    阿里云ESC 安装 MYSQL8.0的教程

    这篇文章主要介绍了阿里云ESC 安装 MYSQL8.0的教程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • MySQL对小数进行四舍五入的操作实现

    MySQL对小数进行四舍五入的操作实现

    数学函数是MySQL中常用的一类函数,其主要用于处理数字,包括整型和浮点数等等,本文主要介绍了MySQL对小数进行四舍五入的操作实现,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08

最新评论