由此牵扯出两个问题,(1)timestamp与datetime的区别;(2)CURRENT_TIMESTAMP为何能用于datetime类型mysql
timestamp与datetime的区别
a)DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),若是不作特殊处理,而且update语句中没有指定该列的更新值,则默认更新为当前时间。
这个区别就解释了为何平时咱们都不用能够管这个字段就能自动更新了,由于多数时候用的是timestamp;而此处用的是datetime,不会有自动更新当前时间的机制,因此须要在上层手动更新该字段sql
b)DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。所以,TIMESTAMP比DATETIME的空间利用率更高。数据库
这个区别解释了为啥timestamp类型用的多io
c)二者的存储方式不同 ,对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不作任何改变,基本上是原样输入和输出。date
d)二者所能存储的时间范围不同 select
timestamp所能存储的时间范围为:’1970-01-01 00:00:01.000000’ 到 ‘2038-01-19 03:14:07.999999’;im
datetime所能存储的时间范围为:’1000-01-01 00:00:00.000000’ 到 ‘9999-12-31 23:59:59.999999’。数据
CURRENT_TIMESTAMP为何能用于datetime类型
在mysql 5.6以前的版本,CURRENT_TIMESTAMP只能用于timestamp类型,
5.6版本以后,CURRENT_TIMESTAMP也能用于datetime类型了
select version()查了一下数据库发现确实版本是5.6.29客户端