时区支持
- 优先使用
TZ
环境变量 - 如果失败,则从
/etc/localtime
的实际软链地址提取。 - 如果上面两种都失败则使用 作为系统时区。
在运行过程中可以修改全局时区:
TiDB 还可以通过设置 session 变量 time_zone
为每个连接维护各自的时区。默认条件下,这个值取的是全局变量 time_zone
的值。修改 session 使用的时区:
SET time_zone = timezone;
设置 time_zone
的值的格式:
- ‘SYSTEM’ 表明使用系统时间
- 相对于 UTC 时间的偏移,比如 ‘+10:00’ 或者 ‘-6:00’
- 某个时区的名字,比如 ‘Europe/Helsinki’,’US/Eastern’ 或 ‘MET’
NOW()
和 的返回值都受到时区设置的影响。
create table t (ts timestamp, dt datetime);
Query OK, 0 rows affected (0.00 sec)
insert into t values ('2017-09-30 11:11:11', '2017-09-30 11:11:11');
set @@time_zone = '+8:00';
Query OK, 0 rows affected (0.00 sec)
上面的例子中,无论怎么调整时区的值,Datetime 类型字段的值是不受影响的,而 Timestamp 则随着时区改变,显示的值会发生变化。其实 Timestamp 持久化到存储的值始终没有变化过,只是根据时区的不同显示值不同。
另外,用户在导数据的过程中,也要需注意主库和从库之间的时区设定是否一致。