mysql设置update时间字段自动更新

Posted 请叫我东子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql设置update时间字段自动更新相关的知识,希望对你有一定的参考价值。

数据库表设计阶段中有个最佳实践,需要在每个表中预留创建时间create_time, 修改时update_time字段

阿里巴巴编码规约中建议命名为gmt_create,gmt_modifie,并且类型datetime

其中,create_time字段在一般开发中会设置默认值为“CURRENT_TIMESTAMP”,create_time设置默认为“CURRENT_TIMESTAMP”。

在之前的开发过程中,习惯将它们的数据类型设置为datetime,然后在业务逻辑中设置修改时间为当前时间,也就是需要sql中显示的设置修改时间。

当前的需求是:

当新增记录的时候,mysql自动将系统的当前时间set到创建时间和更新时间这两个字段中。
当更新记录的时候,mysql只update更新时间字段的时间,而不修改创建时间字段对应的值。

解决方法很简单,只需要找到表中对应的创建时间和更新时间的字段,将其修改为下列代码所示。

创建时间字段

creat_time datetime NULL DEFAULT CURRENT_TIMESTAMP

更新时间字段

update_time datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

核心的DDL语句为

ON UPDATE CURRENT_TIMESTAMP

注意: 因此我们就不需要在代码中对记录设置创建时间和修改时间了。

在navicat中的操作为,

表—右击—>点击 设计表

选中相应的时间字段,设置字段数据类型为CURRENT_TIMESTAMP,同时选中 根据当前时间戳更新 ,这里navicat会帮我们设置 ON UPDATE CURRENT_TIMESTAMP 属性。

create_time的 设置

update_time配置

这样,我们的程序在不用代码中操作时间的情况下每次更新都能够实时将修改时间(create_time)记录到到数据库的记录。

以上是关于mysql设置update时间字段自动更新的主要内容,如果未能解决你的问题,请参考以下文章

mysql某个字段变化timestamp跟着变化

mysql建表时怎样设置datetime类型的字段默认值为不自动更新的系统当前时间

Mysql 添加 create_time, update_time 创建时间 更新时间 自动更新

mysql怎么在创建表时设置默认时间为系统时间

postgresSQL 实现数据修改后,自动更新updated_date/ts等字段

MySQL数据库时间设置自动添加时间和自动更新时间