博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL时区支持
阅读量:7023 次
发布时间:2019-06-28

本文共 1876 字,大约阅读时间需要 6 分钟。

时区支持

使用的时区由 time_zone 全局变量和 session 变量决定。time_zone 的默认值是 SystemSystem 对应的实际时区在 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://blog.51cto.com/13767724/2335122

你可能感兴趣的文章
IOS渠道追踪方式
查看>>
Tomcat服务器环境变量配置及在Eclipse中启动和配置
查看>>
Logistic回归计算过程的推导
查看>>
Centos 查看版本
查看>>
如何在.Net Core 2.0 App中读取appsettings.json
查看>>
译:1. RabbitMQ Java Client 之 "Hello World"
查看>>
Redis 和 Memcached 的区别
查看>>
针对低网速的性能优化
查看>>
golang json 为map[string] interface{}
查看>>
在类中,调用这个类时,用$this->video_model是不是比每次调用这个类时D('Video')效率更高呢...
查看>>
SpringBoot系列: 制作Docker镜像的全过程
查看>>
Java Lambda基础——Function, Consumer, Predicate, Supplier, 及FunctionalInterface接口
查看>>
Sword redis存取二进制数据
查看>>
1.shell学习之常用语句
查看>>
2018-12-24
查看>>
入手腾龙SP AF90mm MACRO
查看>>
pl/sql 与 t-sql 函数对比
查看>>
关于delphi中多线程采用定时器的做法
查看>>
Adobe Audition 3.0消除人声技巧二则
查看>>
linux下串口控制
查看>>