数据库表的规范:必须三个字段 1.id 2.创建时间 3.更新时间
解决方案:(自动填充方案)
1.数据库级别: 修改数据库数据类型:CURRENT_TIMESTAMP (更新时间字段勾选更新)
`create_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
2.业务逻辑:添加字段数据
mybatis_plus:(1)实体上增加字段并添加注解
@Data
public class User {
@TableField(fill = FieldFill.INSERT)
private Date createTime;
//@TableField(fill = FieldFill.UPDATE)
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
}
(2)实现元对象处理器接口(不要忘记添加 @Component 注解)
package com.atguigu.mybatisplus.handler;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.util.Date;
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) { //创建时自填装数据
log.info("start insert fill ....");
this.setFieldValByName("createTime", new Date(), metaObject);
//(实体类属性名字,数据类型,填充字段元数据)
this.setFieldValByName("updateTime", new Date(), metaObject);
}
@Override
public void updateFill(MetaObject metaObject) { //更新时候自动填装数据
log.info("start update fill ....");
this.setFieldValByName("updateTime", new Date(), metaObject);
}
}