如何在MySQL中使用CURRENT_TIMESTAMP实现多个TIMESTAMP字段?

Mary-Kate Olsen
发布: 2024-11-05 16:45:02
原创
918 人浏览过

How to Implement Multiple TIMESTAMP Fields with CURRENT_TIMESTAMP in MySQL?

MySQL:支持具有 CURRENT_TIMESTAMP 的多个 TIMESTAMP 字段

MySQL 文档规定,一张表只能有一个 TIMESTAMP 列,其中 CURRENT_TIMESTAMP 值为DEFAULT 或 ON UPDATE 子句。当您想要跟踪记录的创建和更新时间戳时,这可能会受到限制。

错误处理

当您尝试创建包含多个记录的表时使用 CURRENT_TIMESTAMP 的 TIMESTAMP 列,您将遇到如下错误:

ERROR 1293 (HY000): Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
登录后复制

解决方案

最近版本的 MySQL(5.6.25 及更高版本)已解决此问题局限性。您现在可以定义具有多个 TIMESTAMP 列的表,每个列都有自己的 CURRENT_TIMESTAMP 行为。下面是一个示例:

<code class="sql">CREATE TABLE `msgs` (
    `id` INT PRIMARY KEY AUTO_INCREMENT,
    `msg` VARCHAR(256),
    `ts_create` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    `ts_update` TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);</code>
登录后复制

使用此更新的语法,当插入新记录或更新现有记录时,ts_create 和 ts_update 列都将自动设置为当前时间戳。

以上是如何在MySQL中使用CURRENT_TIMESTAMP实现多个TIMESTAMP字段?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板