1. 基本区别:
2. 其他特性:
1. TIMESTAMP是以utc格式存储,会自动检索当前时区对时间进行转换,而DATETIME不会。
2. 存入null时,TIMESTAMP会自动存储当前时间,而DATETIME存储null值。
3. 时间计算:
DATETIME翻译为汉语即"时间戳",它是当前时间到 Unix元年(1970 年 1 月 1 日 0 时 0 分 0 秒)的秒数。对于某些时间的计算,如果是以 DATETIME 的形式会比较困难,假如我是 1994-1-20 06:06:06 出生,现在的时间是 2016-10-1 20:04:50 ,那么要计算我活了多少秒钟, DATETIME还需要函数进行转换,但是 TIMESTAMP 直接相减就行。
3. 什么场景下用什么类型合适呢?
1.需要跨时区计算时间用 或者 需要自动更新时间的TIMESTAMP
计算一架从北京飞往纽约的飞机的飞行时间。这个场景中,如果使用 TIMESTAMP 来存时间,起飞和降落时间的值,都会被转换成 UTC 时间,所以它们直接相减即可获得结果。但如果使用 DATATIME 格式存时间,还需要进行转换,才可以完成,容易出错。
2.记录创建修改时间 或者 时间范围大于2038 用DATETIME
DATATIME作为记录时间,现在都已经2022年了,很快就到2