您好,匿名用户
随意问技术百科期待您的加入

Mysql时间字段格式如何选择,TIMESTAMP,DATETIME,INT?

0 投票

Mysql的时间字段貌似有各种选择,像一般的情况(我也是)下就是用INT型来表示,直接存储时间戳。但是我知道在Mysql里至少还有TIMESTAMPDATETIME型可以用来存储时间,我不知道这三者在使用上各有什么区别,在使用场景上需要怎么考虑,特别是它们在索引或者查询速度上有区别吗?

用户头像 提问 2012年 12月1日 @ Pisces 上等兵 (182 威望)
分享到:

1个回答

0 投票
 
最佳答案

首先 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作为索引,如果碰到大量数据查询慢的情况,也可以分区表解决。

用户头像 回复 2012年 12月1日 @ Zilean 上等兵 (230 威望)
选中 2012年 12月1日 @Pisces
提一个问题:

相关问题

0 投票
1 回复 27 阅读
用户头像 提问 2013年 11月15日 @ Karthus 上等兵 (227 威望)
0 投票
1 回复 31 阅读
用户头像 提问 2013年 12月5日 @ Miss Fortune 上等兵 (418 威望)
+3 投票
1 回复 378 阅读
用户头像 提问 2012年 12月8日 @ 匿名用户
0 投票
1 回复 37 阅读
用户头像 提问 2012年 12月1日 @ Karthus 上等兵 (227 威望)

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...