Mysql:时区问题

Mysql:时区问题

1、时区配置

  • Mysql默认使用系统的时区
mysql 复制代码
mysql> show global variables like '%time%zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | SYSTEM |	# 表明使用系统时间
+------------------+--------+
2 rows in set, 1 warning (0.17 sec)

mysql>
  • 在Mysql配置文件中设置时区

修改完配置之后,需要重启MySQL服务,否则不生效。

ini 复制代码
[mysqld]

# 设置默认时区
# default-time-zone='+08:00'

修改之后在终端查看是否生效

mysql 复制代码
mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | +08:00 |
+------------------+--------+
2 rows in set, 1 warning (0.03 sec)

mysql>
# 设置新的时区
mysql>  SET TIME_ZONE = '-6:00';
Query OK, 0 rows affected (0.00 sec)
# 查看设置的时区是否生效
mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | -06:00 |
+------------------+--------+
2 rows in set, 1 warning (0.00 sec)

mysql> 

2、时区影响了什么

2.1、now() curtime()系统函数的影响

mysql 复制代码
mysql> select now(), curtime();
+---------------------+-----------+
| now()               | curtime() |
+---------------------+-----------+
| 2024-07-09 16:27:06 | 16:27:06  |
+---------------------+-----------+
1 row in set (0.02 sec)

mysql>
mysql>
mysql>  show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set, 1 warning (0.00 sec)

mysql>
mysql>
mysql> SET TIME_ZONE = '-6:00';
Query OK, 0 rows affected (0.00 sec)

mysql>  show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | -06:00 |
+------------------+--------+
2 rows in set, 1 warning (0.00 sec)

# 修改时区之后,系统返回返回的值相应的也变化了
mysql> select now(), curtime();
+---------------------+-----------+
| now()               | curtime() |
+---------------------+-----------+
| 2024-07-09 02:28:03 | 02:28:03  |
+---------------------+-----------+
1 row in set (0.00 sec)

mysql>

2.2、timestamp 数据类型字段存储的数据受时区影响

  • timestamp 数据类型会存储当时session的时区信息,读取时会根据当前 session 的时区进行转换;

  • datetime 数据类型插入的是什么值,再读取就是什么值,不受时区影响。

    也可以理解为已经存储的数据是不会变的,只是 timestamp 类型数据在读取时会根据时区转换。

mysql 复制代码
mysql> show global variables like '%time%zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set, 1 warning (0.17 sec)

mysql> create table datedemo
    -> (
    ->  mydatetime datetime,
    ->  mytimestamp timestamp
    -> );
Query OK, 0 rows affected (0.17 sec)

mysql>  select * from datedemo;
+---------------------+---------------------+
| mydatetime          | mytimestamp         |
+---------------------+---------------------+
| 2024-07-09 16:06:32 | 2024-07-09 16:06:32 |
| 2024-07-09 16:07:09 | NULL                |
| NULL                | NULL                |
+---------------------+---------------------+
3 rows in set (0.01 sec)

mysql>  SET TIME_ZONE = '-6:00';
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone |        |
| time_zone        | -06:00 |
+------------------+--------+
2 rows in set, 1 warning (0.00 sec)

mysql> select * from datedemo;
+---------------------+---------------------+
| mydatetime          | mytimestamp         |
+---------------------+---------------------+
| 2024-07-09 16:06:32 | 2024-07-09 02:06:32 |# mytimestamp字段显示的值发生了转换
| 2024-07-09 16:07:09 | NULL                |
| NULL                | NULL                |
+---------------------+---------------------+
3 rows in set (0.00 sec)

mysql>
相关推荐
于眠牧北15 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
WeiXin_DZbishe3 天前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
爱可生开源社区3 天前
MySQL 性能优化:真正重要的变量
数据库·mysql
小马爱打代码3 天前
MySQL性能优化核心:InnoDB Buffer Pool 详解
数据库·mysql·性能优化
风流 少年3 天前
mysql mcp
数据库·mysql·adb
西门吹雪分身4 天前
mysql之数据离线迁移
数据库·mysql
轩情吖4 天前
MySQL初识
android·数据库·sql·mysql·adb·存储引擎