mysql的时区_MySQL时区支持

mysql的时区_MySQL时区支持时区支持使用的时区由 time zone 全局变量和 session 变量决定 time zone 的默认值是 System System 对应的实际时区在 TiDB 集群 bootstrap 初始化时设置 具体逻辑如下 优先使用 TZ 环境变量如果失败 则从 etc localtime 的实际软链地址提取 如果上面两种都失败则使用 UTC 作为系统时区 在运行过程中可以修改全局时区 mysql

时区支持

使用的时区由 time_zone 全局变量和 session 变量决定。time_zone 的默认值是 System,System 对应的实际时区在 TiDB 集群 bootstrap 初始化时设置。具体逻辑如下:

优先使用 TZ 环境变量

如果失败,则从 /etc/localtime 的实际软链地址提取。

如果上面两种都失败则使用 UTC 作为系统时区。

在运行过程中可以修改全局时区:

mysql> set global time_zone=’+8:00′; # 因为UTC时区 修改时间 建议使用

mysql> SET GLOBAL time_zone = timezone; # 根据具体情况使用,不建议禁止使用

TiDB 还可以通过设置 session 变量 time_zone 为每个连接维护各自的时区。默认条件下,这个值取的是全局变量 time_zone 的值。修改 session 使用的时区:

mysql> SET time_zone = timezone;

查看当前使用的时区的值:

mysql> SELECT @@global.time_zone, @@session.time_zone;

设置 time_zone 的值的格式:

‘SYSTEM’ 表明使用系统时间

相对于 UTC 时间的偏移,比如 ‘+10:00’ 或者 ‘-6:00’

某个时区的名字,比如 ‘Europe/Helsinki’, ‘US/Eastern’ 或 ‘MET’

NOW() 和 CURTIME() 的返回值都受到时区设置的影响。

注意,只有 Timestamp 数据类型的值是受时区影响的。可以理解为, Timestamp 数据类型的实际表示使用的是 (字面值 + 时区信息)。其它时间和日期类型,比如 Datetime/Date/Time 是不包含时区信息的,所以也不受到时区变化的影响。

mysql> select now(); # 当前

+———————+

| now() |

+———————+

| 2018-12-25 11:11:11 |

+———————+

1 row in set (0.00 sec)

mysql> create table t (ts timestamp, dt datetime);

Query OK, 0 rows affected (0.02 sec)

mysql> set @@time_zone = ‘UTC’;

Query OK, 0 rows affected (0.00 sec)

mysql> insert into t values (‘2018-12-25 11:11:11’, ‘2018-12-25 11:11:11’);

Query OK, 1 row affected (0.00 sec)

mysql> set @@time_zone = ‘+8:00’;

Query OK, 0 rows affected (0.00 sec)

mysql> select * from t;

+———————|———————+

| ts | dt |

+———————|———————+

| 2018-12-25 11:11:11 | 2018-12-25 11:11:11 |

+———————|———————+

1 row in set (0.00 sec)

上面的例子中,无论怎么调整时区的值, Datetime 类型字段的值是不受影响的,而 Timestamp 则随着时区改变,显示的值会发生变化。其实 Timestamp 持久化到存储的值始终没有变化过,只是根据时区的不同显示值不同。

Timestamp 类型和 Datetime 等类型的值,两者相互转换的过程中,会涉及到时区。这种情况一律基于 session 的当前 time_zone 时区处理。

另外,在导数据的过程中,也要需注意主库和从库之间的时区设定是否一致。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/202480.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月20日 上午7:02
下一篇 2026年3月20日 上午7:02


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号