0

我偶然发现了日期值大于当前日期的mysql时间戳插入问题,现在以下步骤是

CREATE TABLE foo(
`ID` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`test_time`TIMESTAMP NULL DEFAULT NULL,
PRIMARY KEY (`ID`)
); 

INSERT INTO foo(test_time) VALUES('2038-01-19 11:14:08'); // fail
INSERT INTO foo(test_time) VALUES('2038-01-19 11:14:07'); // ok
INSERT INTO foo(test_time) VALUES('2038-01-18 23:59:00'); // ok
INSERT INTO foo(test_time) VALUES('2039-01-01 00:00:00'); // fail

失败意味着 test_time 值为 0000-00-00 00:00:00 我的时区是 UTC+8 我想知道 2038-01-19 11:14:07 是否是 mysql 支持的最大时间戳,什么是有意义的时刻这次?

4

1 回答 1

4

要存储更高的日期值,您必须使用DATETIME数据类型。

TIMESTAMP范围从'1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07' UTC

DATETIME范围从'1000-01-01 00:00:00' to '9999-12-31 23:59:59'

http://dev.mysql.com/doc/refman/5.5/en/datetime.html

正如@Joachim Isaksson 所建议的那样:PHP 和 mySQL:2038 年错误:它是什么?如何解决?

于 2012-08-08T05:18:53.177 回答