mysql 数据类型TIMESTAMP
程序员文章站
2024-02-29 10:42:40
在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不使用程序更新情况下只要你更新了记录timestamp会自动更新时间
通常表中会有一个cr...
在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子句,这个时间戳会自动更新,否则该列有一个默认的常量但不会自动更新。
换句话说,你可以使用当前的时间戳去初始化值和自动更新,或者是其中之一,也可以都不是。(比如,你在定义的时候可以指定自动更新,但并不初始化。)