为了账号安全,请及时绑定邮箱和手机立即绑定

对于时间字段格式我该如何选择,TIMESTAMP,DATETIME,INT?

对于时间字段格式我该如何选择,TIMESTAMP,DATETIME,INT?

30秒到达战场 2023-04-14 17:13:18
Mysql的时间字段貌似有各种选择,像一般的情况(我也是)下就是用INT型来表示,直接存储时间戳。但是我知道在Mysql里至少还有TIMESTAMP和DATETIME型可以用来存储时间,我不知道这三者在使用上各有什么区别,在使用场景上需要怎么考虑,特别是它们在索引或者查询速度上有区别吗?
查看完整描述

2 回答

?
慕田峪7331174

TA贡献1828条经验 获得超13个赞

首先 DATETIM和TIMESTAMP类型所占的存储空间不同,前者8个字节,后者4个字节,这样造成的后果是两者能表示的时间范围不同。前者范围为1000-01-01 00:00:00 ~ 9999-12-31 23:59:59,后者范围为1970-01-01 08:00:01到2038-01-19 11:14:07。所以可以看到TIMESTAMP支持的范围比DATATIME要小,容易出现超出的情况.

其次,TIMESTAMP类型在默认情况下,insert、update 数据时,TIMESTAMP列会自动以当前时间(CURRENT_TIMESTAMP)填充/更新。

第三,TIMESTAMP比较受时区timezone的影响以及MYSQL版本和服务器的SQL MODE的影响

所以一般来说,我比较倾向选择DATETIME,至于你说到索引的问题,选择DATETIME作为索引,如果碰到大量数据查询慢的情况,也可以分区表解决。


查看完整回答
反对 回复 2023-04-17
?
蝴蝶不菲

TA贡献1810条经验 获得超4个赞

两者都是时间类型字段,格式都一致。两者主要有以下四点区别:

  • 最主要的区别-受时区影响不同。timestamp会跟随设置的时区变化而变化,而datetime保存的是绝对值不会变化。


查看完整回答
反对 回复 2023-04-17
  • 2 回答
  • 0 关注
  • 104 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信