【转载】:MySQL中有关TIMESTAMP和DATETIME的总结html
二者均可以用来表示YYYY-MM-DD HH:MM:SS[.fraction]类型的日期。post
对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。测试
而对于DATETIME,不作任何改变,基本上是原样输入和输出。url
timestamp所能存储的时间范围为:'1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999'。htm
datetime所能存储的时间范围为:'1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999'。blog
总结:TIMESTAMP和DATETIME除了存储范围和存储方式不同,没有太大区别。固然,对于跨时区的业务,TIMESTAMP更为合适。ci
默认状况下,数据表会对第一个 timestamp 字段设置为 not null,并在记录更新时自动更新该字段的值为当前时间;get
测试:it
查看是否开启自动初始化和更新:io
show variables like '%explicit_defaults_for_timestamp%';
禁用自动初始化和更新:
1. 将“explicit_defaults_for_timestamp”的值设置为ON。
2. “explicit_defaults_for_timestamp”的值依旧是OFF,也有两种方法能够禁用
1> 用DEFAULT子句该该列指定一个默认值
2> 为该列指定NULL属性。