为什么mysql 的TIMESTAMP 字段 不能插入0呢

为什么mysql 的TIMESTAMP 字段 不能插入0呢,第1张

timestamp类型的起始时间是1970-01-01 00:00:01 UTC,和时区是关系的。MySQL将timestamp类型的值保存的时候,会从当前时区转成UTC时间,正好解释了前面1970-01-01 08:00:00或1970-01-01 00:00:01两个值保存时出错的问题了。即时间小于1970-01-01 08:00:00都是不允许的。因为从当前时区转成UTC时间需要减去『8小时』,结果就不在timestamp类型的范围内了。

在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不使用程序更新情况下只要你更新了记录timestamp会自动更新时间

通常表中会有一个Create

date

创建日期的字段,其它数据库均有默认值的选项。MySQL也有默认值timestamp,但在MySQL中,不仅是插入就算是修改也会更新timestamp的值!

这样一来,就不是创建日期了,当作更新日期来使用比较好!

因此在MySQL中要记录创建日期还得使用datetime

然后使用NOW()

函数完成!

1:

如果定义时DEFAULT

CURRENT_TIMESTAMP和ON

UPDATE

CURRENT_TIMESTAMP子句都有,列值为默认使用当前的时间戳,并且自动更新。

2:

如果不使用DEFAULT或ON

UPDATE子句,那么它等同于DEFAULT

CURRENT_TIMESTAMP

ON

UPDATE

CURRENT_TIMESTAMP。

3:

如果只有DEFAULT

CURRENT_TIMESTAMP子句,而没有ON

UPDATE子句,列值默认为当前时间戳但不自动更新。

4:

如果没用DEFAULT子句,但有ON

UPDATE

CURRENT_TIMESTAMP子句,列默认为0并自动更新。

5:

如果有一个常量值DEFAULT,该列会有一个默认值,而且不会自动初始化为当前时间戳。如果该列还有一个ON

UPDATE

CURRENT_TIMESTAMP子句,这个时间戳会自动更新,否则该列有一个默认的常量但不会自动更新。

换句话说,你可以使用当前的时间戳去初始化值和自动更新,或者是其中之一,也可以都不是。(比如,你在定义的时候可以指定自动更新,但并不初始化。)

Mysql中经常用来存储日期的数据类型有三种:Date、Datetime、Timestamp。Date数据类型:用来存储没有时间的日期。Mysql获取和显示这个类型的格式为“YYYY-MM-DD”。支持的时间范围为“1000-00-00”到“9999-12-31”。Datetime类型:存储既有日期又有时间的数据。存储和显示的格式为 “YYYY-MM-DD HH:MM:SS”。支持的时间范围是“1000-00-00 00:00:00”到“9999-12-31 23:59:59”。Timestamp类型:也是存储既有日期又有时间的数据。存储和显示的格式跟Datetime一样。支持的时间范围是“1970-01-01 00:00:01”到“2038-01-19 03:14:07”。所有不符合上面所述格式的数据都会被转换为相应类型的0值。(0000-00-00或者0000-00-00 00:00:00)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8374399.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-15
下一篇 2023-04-15

发表评论

登录后才能评论

评论列表(0条)

保存