【MySQL-技术】MySQL数据库自动添加创建时间、更新时间(超详细版)

一、MySQL5.7及以上版本(也适用于MySQL8.0+)方法


下列给出了三种不同时期修改表的SQL,便于各位看官快捷开发(CV大法)

1、新建表

自动获取创建时间timestamp not null default CURRENT_TIMESTAMP

自动获取更新时间timestamp not null default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP

create table test(
  id integer not null auto_increment primary key,
  name varchar(20) not null ,
  create_time timestamp not null default CURRENT_TIMESTAMP COMMENT '创建时间',
  update_time timestamp not null default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP COMMENT '更新时间');

2、修改表字段 (快捷复制)

ALTER TABLE 表名 MODIFY [修改字段名] <数据类型> [约束条件];

 ALTER TABLE test MODIFY create_time timestamp not null default CURRENT_TIMESTAMP COMMENT '创建时间';
 ALTER TABLE test MODIFY update_time timestamp not null default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP COMMENT '更新时间';

3、新增表字段(快捷复制)

ALTER TABLE <表名> ADD <新字段名> <数据类型> [约束条件];

 ALTER TABLE test ADD create_time timestamp not null default CURRENT_TIMESTAMP COMMENT '创建时间';
 ALTER TABLE test ADD update_time timestamp not null default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP COMMENT '更新时间';





----------------------------------------------------分割线----------------------------------------------------

二、MySQL5.7以下版本方法


1、方法

上述方法在MySQL 5.7以下版本中会报错。同表出现两个以上timestamp格式列的默认值都为CURRENT_TIMESTAMP时,会有错误提示:1293 - Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause

解决办法

create table test(
id integer not null auto_increment primary key,
  name varchar(20) not null ,
  created timestamp not null default '0000-00-00 00:00:00',
  updated timestamp not null default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP
);

当用SQL插入记录时,createtime值设置为null,createtime字段就会自动获取系统当前时间。


2、注意事项(附录)
2.1 不能手动添加数据

一定不能用手动在数据库添加数据的方式,否则createtime的值不是当前时间,而会是'0000-00-00 00:00:00',一定要用insert方法,然后createtime值为null即可:insert into table_name (id,createtime) values (1,null);

2.2 createtime必填,不写≠赋值为null

添加数据时,createtime字段必填,不填会出现createtime值为'0000-00-00 00:00:00'

2.3 通过Navicat等数据库管理工具直接修改表自动更新时间

1、createtime、updatetime字段类型修改为timestamp
2、createtime、updatetime字段勾选上不是null
3、createtime的默认值设为'0000-00-00 00:00:00'
4、updatetime的默认值为CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP
5、mysql5.6版本以下的createtime字段一定不能勾选根据当前时间戳更新,否则创建会报错[Err] 1293 - Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTA

createtime字段
在这里插入图片描述

updatetime字段
在这里插入图片描述

  • 45
    点赞
  • 156
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天呐少爷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值