Mysql CURRENT_TIMESTAMP
在创建时间字段的时候
DEFAULT CURRENT_TIMESTAMP
表示当插入数据的时候,该字段默认值为当前时间
ON UPDATE CURRENT_TIMESTAMP
表示每次更新这条数据的时候,该字段都会更新成当前时间
这两个操作是mysql数据库本身在维护,所以可以根据这个特性来生成【创建时间】和【更新时间】两个字段,且不需要代码来维护
如下:
CREATE TABLE `sys_dept` ( `dept_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '部门id', `dept_name` varchar(255) DEFAULT '' COMMENT '部门名称', `sequence` int(10) DEFAULT '0' COMMENT '排序', `parent_id` bigint(20) DEFAULT '0' COMMENT '父id', `create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间', `create_by` varchar(255) DEFAULT '' COMMENT '创建人', `update_by` varchar(255) DEFAULT '' COMMENT '修改人', `is_valid` tinyint(2) NOT NULL DEFAULT '1' COMMENT '逻辑有效 0.无效1.有效', `remark` varchar(255) DEFAULT '' COMMENT '备注', PRIMARY KEY (`dept_id`) ) ENGINE=InnoDB AUTO_INCREMENT DEFAULT CHARSET=utf8mb4;
可以通过navicat的可视化界面直接操作