下列给出了三种不同时期修改表的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);
添加数据时,createtime字段必填,不填会出现createtime值为'0000-00-00 00:00:00'
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字段
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)