出于统计原因,我有一个包含数百万次写入的日志记录表。所有列都是 int 外键。我还将为每一行添加一个时间戳列。鉴于 DATETIME 需要 8 位 - 我将使用int(10) unsigned
将存储空间(以及该列上的索引)减半。
但是,我想知道这个专栏什么时候不再起作用。在 2038 年 1 月 19 日凌晨 3:14:07,值 9,999,999,999 将成为 UNIX 时间戳的问题 - 但 MySQL 中的 unsigned int 最多只能容纳 4,294,967,295,并且时间戳 4294967295 在我的 PHP 应用程序中显示无效数字。
那么这是什么意思?MySQL 中存储 int 时间戳的结束是否会在 2021 年某个时候结束,因为它无法一直到 9999999999?
回答:
- 2147483647 是 2038(不是 9999999999)所以没有问题。
unsigned
不需要,因为 2147483647 非常适合已签名的 MySQL int。