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

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

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

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

2 回答

?
达令说

TA贡献1821条经验 获得超6个赞

首先DATETIM和TIMESTAMP类型所占的存储空间不同,前者8个字节,后者4个字节,这样造成的后果是两者能表示的时间范围不同。前者范围为1000-01-0100:00:00~9999-12-3123:59:59,后者范围为1970-01-0108:00:01到2038-01-1911:14:07。所以可以看到TIMESTAMP支持的范围比DATATIME要小,容易出现超出的情况.其次,TIMESTAMP类型在默认情况下,insert、update数据时,TIMESTAMP列会自动以当前时间(CURRENT_TIMESTAMP)填充/更新。第三,TIMESTAMP比较受时区timezone的影响以及MYSQL版本和服务器的SQLMODE的影响所以一般来说,我比较倾向选择DATETIME,至于你说到索引的问题,选择DATETIME作为索引,如果碰到大量数据查询慢的情况,也可以分区表解决。
                            
查看完整回答
反对 回复 2019-03-29
?
心有法竹

TA贡献1866条经验 获得超5个赞

其实速度上差别不是很大,你可以自己做做测试就知道了。内部存储都是整数,只不过datetime和timestamp会仅仅在显示的时候,显示为人能读的日期(当然存储空间有点区别,整形和timestamp都是4字节,datetime是8字节),做索引也应该没什么区别,这个不敢确定,如果有请指正我……另外datetime和timestamp相对于int来说也有一个小小的好处,就是对于时间类型来说,可以有一系列的时间函数可以用这几个类型的选择还是看你的需求。我用timestamp比较多,对于记录日志什么的需求,timestamp绝对够用了,除非你保证说你的程序能一直用到2038年,就算如此也可以用迁移程序处理……如果需求是允许用户保存一些超过timestamp能保存的时间(@QingchaoWu已经给出了timestamp的范围)比如说todolist什么的,允许用户计划38年以后的事情,那就用datetime好了。
                            
查看完整回答
反对 回复 2019-03-29
  • 2 回答
  • 0 关注
  • 337 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号