首页 > 数据库 > MySQL > 正文

mysql 数据类型TIMESTAMP

2024-07-24 12:47:02
字体:
来源:转载
供稿:网友

在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 5.6 中 TIMESTAMP有那些变化MySQL 5.6 中的 TIMESTAMP 和 explicit_defaults_for_timestamp 参数MySQL 5.6 中 TIMESTAMP 的变化分析MySQL 5.6 中TIMESTAMP with implicit DEFAULT value is deprecated错误Mysql中的Datetime和Timestamp比较mysql之TIMESTAMP(时间戳)用法详解MySQL错误TIMESTAMP column with CURRENT_TIMESTAMP的解决方法解析mysql中UNIX_TIMESTAMP()函数与php中time()函数的区别MySQL timestamp自动更新时间分享mysql多个TimeStamp设置的方法解读mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数MySQL timestamp的类型与时区实例详解
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表