MySQL datetime 和 timestamp 的区别

【转载】:MySQL中有关TIMESTAMP和DATETIME的总结html

1. datetime 和 timestamp 的相同点

  二者均可以用来表示YYYY-MM-DD HH:MM:SS[.fraction]类型的日期。测试

2. datetime 和 timestamp 的不一样点

2.1 存储方式

  对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。url

  而对于DATETIME,不作任何改变,基本上是原样输入和输出。spa

2.2 存储范围

  timestamp所能存储的时间范围为:'1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999'。.net

  datetime所能存储的时间范围为:'1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999'。htm

   总结:TIMESTAMP和DATETIME除了存储范围和存储方式不同,没有太大区别。固然,对于跨时区的业务,TIMESTAMP更为合适。blog

3. datetime 和 timestamp 的自动初始化和自动更新

  默认状况下,数据表会对第一个 timestamp 字段设置为 not null,并在记录更新时自动更新该字段的值为当前时间;ci

  测试:get

  

3.1 设置自动初始化和更新

  查看是否开启自动初始化和更新:it

  show variables like '%explicit_defaults_for_timestamp%';

  

  禁用自动初始化和更新:

  1. 将“explicit_defaults_for_timestamp”的值设置为ON。

  2. “explicit_defaults_for_timestamp”的值依旧是OFF,也有两种方法能够禁用

       1> 用DEFAULT子句该该列指定一个默认值

       2> 为该列指定NULL属性。

相关文章
相关标签/搜索