欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL 时间类型的选择

程序员文章站 2022-03-22 17:17:41
mysql 提供了 datetime 和 timestamp 两种非常相似的类型处理日期和时间,大部分情况下两种都是 ok 的,但是有些情况二者会互有优劣。datetimedatetime 的时间跨度...

mysql 提供了 datetime 和 timestamp 两种非常相似的类型处理日期和时间,大部分情况下两种都是 ok 的,但是有些情况二者会互有优劣。

datetime

datetime 的时间跨度更大,可以从1001年到9999年,精度是秒。并且存储的格式是将日期和时间打包使用 yyyymmddhhmmss格式的整数存储,这个时间与时区无关,需要占用8个字节的存储空间。默认,mysql 显示 的datetime是有序的,明确的格式,例如2021-06-02 18:35:23。这是 ansi 的标准日期时间格式。

timestamp

timestamp即时间戳,存储的是自格林威治时间(gmt)1970年1月1日零点以来的秒数。和 unix 系统的时间戳一样。timestamp 仅需要4个字节存储,因此能够表示的时间跨度更小,从1970年到2038年。mysql 提供了 from_unixtime 和 unix_timestamp 函数来完成时间戳和日期之间的转换。

在 mysql 4.1版本后,timestamp 显示的格式和 datetime 类似,但是,timestamp 的显示依赖于时区。mysql 的服务端、操作系统以及客户端连接都有时区的设置。因此,如果时间是从多个时区存储的话,那 timestamp 和 datetime 的差别就会很大。timestamp 会保留使用时的时区信息,而 datetime 仅仅是使用文本表示时间。

timestamp 还有额外的特性。默认地,mysql会在没有指定值的情况下使用当前时间插入到 timestamp列,而更新的时候如果没有指定值会使用当前时间更新该字段,以下面的测试表为例:

create table t_time_test (
    id int primary key,
    t_stamp timestamp,
    t_datetime datetime
);

可以看到mysql 给的默认值就是当前时间戳 current_timestamp,并且有个 on update current_timestamp表示会随之更新:

MySQL 时间类型的选择

insert into t_time_test(id, t_datetime) values
	(1, null), 
	(2, '2021-06-02 18:48:04'), 
	(3, null);

可以看到 t_stamp 列自动填充了当前时间。

MySQL 时间类型的选择

这个特性使得我们可以物协程序维护数据更新时间字段,而交由 mysql 完成。

如何选择

从特性上看,可能会优先选择使用 timestamp 来存储时间,相比 datetime 来说更高效。也有些人使用整数存储 unix 时间戳,实际上这种方式并不能获益,而且整数还需要额外进行处理,因此并不推荐这么做。但是一些情况需要注意不要使用 timestamp 存储时间:

  • 生日:生日肯定会有早于1970年的,会超出 timestamp 的范围
  • 有效期截止时间:timestamp 的最大时间是2038年,如果用来存类似身份证的有效期截止时间,营业执照的截止时间等就不合适。
  • 业务生存时间:互联网时代讲究快,发展(死得)快。如果要成为长久存在的企业,那么你的业务时间很可能在2038年还在继续运营,毕竟现在都2021年了。如果你觉得公司业务挺不到2038年,那没关系。当然,如果幸运地挺到2038年,请务必写下一条待办事项:到2038年1月1日前修改数据表时间戳字段类型。

如何存储毫秒级时间

通常这个时候需要使用 bigint 来将时间转换为整型存储,或者是使用浮点数,用分数部分表示秒精度一下的时间,这两种方式都可行。当然,这个时候需要应用支持做格式转换。

结语

从安全稳妥的角度考虑,建议还是优先选择 datetime 类型,虽然相比 timestamp 会牺牲一点性能,但是 timestamp 的时间范围是硬伤,不要埋下一个隐患,等到真的2038年,你的公司可能是上市公司的时候,程序员可能会遭遇洪水般的 bug 冲击而不明所以,结果公司的股价迎来闪崩!然后找出来这个程序员,发现是曾经公司的大神,目前的股东,已经实现财务*的你!你说尴尬不尴尬?

以上就是mysql 时间类型的选择的详细内容,更多关于mysql 时间类型的资料请关注其它相关文章!

相关标签: MySQL 时间类型