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>
相关推荐
武子康44 分钟前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql
黑色叉腰丶大魔王1 小时前
《MySQL 数据库备份与恢复》
mysql
Ljw...1 小时前
索引(MySQL)
数据库·mysql·索引
OpsEye1 小时前
MySQL 8.0.40版本自动升级异常的预警提示
数据库·mysql·数据库升级
Ljw...1 小时前
表的增删改查(MySQL)
数据库·后端·mysql·表的增删查改
i道i9 小时前
MySQL win安装 和 pymysql使用示例
数据库·mysql
Oak Zhang10 小时前
sharding-jdbc自定义分片算法,表对应关系存储在mysql中,缓存到redis或者本地
redis·mysql·缓存
久醉不在酒12 小时前
MySQL数据库运维及集群搭建
运维·数据库·mysql
WindFutrue12 小时前
使用Mybatis向Mysql中的插入Point类型的数据全方位解析
数据库·mysql·mybatis
一只爱撸猫的程序猿13 小时前
一个简单的Linux 服务器性能优化案例
linux·mysql·nginx