文档首页/ 云数据库 RDS/ 故障排除/ RDS for MySQL/ SQL类/ 建表时timestamp字段默认值无效
更新时间:2022-10-26 GMT+08:00

建表时timestamp字段默认值无效

场景描述

执行建表SQL语句失败,报错:ERROR 1067: Invalid default value for 'session_start'

CREATE TABLE cluster_membership
(
...
session_start TIMESTAMP DEFAULT '1970-01-01 00:00:01',
...
);

原因分析

关于timestamp字段:MySQL会把该字段插入的值从当前时区转换成UTC时间(世界标准时间)存储,查询时,又将其从UTC时间转化为当前时区时间返回。

timestamp类型字段的时间范围:'1970-01-01 00:00:01' UTC -- '2038-01-19 03:14:07' UTC,详见官方文档

使用如下命令查看时区:

show variables like "%zone%";

由于使用的是UTC +8时区,所以timestamp字段默认值需要加8小时才是有效范围,即有效支持的范围是从1970-01-01 08:00:01开始。

解决方案

修改timestamp字段的默认值:

session_start TIMESTAMP DEFAULT '1970-01-01 08:00:01',