二.MyBatis-plus的自动填充数据
程序员文章站
2022-06-28 18:32:06
二 MyBatis-Plus的自动填充1.以数据库表中的字段举例,因为创建时间、修改时间!这些个操作一遍都是自动化完成的,我们不希望手动更新!阿里巴巴开发手册:所有的数据库表:gmt_create、gmt_modifified几乎所有的表都要配置上!而且需要自动化!换成通俗易懂的就是createTime和updateTime2.在数据库中新增字段createTime和updateTime,使用datetime属性3.在实体层上增加这两个实体类@TableField(fill = Field...
二 MyBatis-Plus的自动填充
1.以数据库表中的字段举例,因为创建时间、修改时间!这些个操作一遍都是自动化完成的,我们不希望手动更新!
阿里巴巴开发手册:所有的数据库表:gmt_create、gmt_modifified几乎所有的表都要配置上!而且需
要自动化!
换成通俗易懂的就是createTime和updateTime
2.在数据库中新增字段createTime和updateTime,使用datetime属性
3.在实体层上增加这两个实体类
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
注意:1.字段必须声明TableField
注解,属性fill
选择对应策略,该声明告知Mybatis-Plus
需要预留注入SQL
字段
2.要想根据注解FieldFill.xxx
和字段名
以及字段类型
来区分必须使用父类的strictInsertFill
或者strictUpdateFill
方法
下面是具体的源码
public enum FieldFill {
/**
* 默认不处理
*/
DEFAULT,
/**
* 插入填充字段
*/
INSERT,
/**
* 更新填充字段
*/
UPDATE,
/**
* 插入和更新填充字段
*/
INSERT_UPDATE
}
4.配置
@Slf4j
@Component
public class MyBatisplusConfig 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) {
this.setFieldValByName("updateTime",new Date(),metaObject);
}
注意 : 1. 需要继承MetaObjectHandler,实现其中的两个方法,插入填充还有修改填充
- createTime是你pojo层@TableField(fill = FieldFill.INSERT)注解下面的字段
- new Date()是赋予我们现在时间的值
- 这个metaObject是传过去的对象
5.测试
@Test
void update(){
user user1=new user();
user1.setId(1);
user1.setUsername("王彦思12");
int i = usermapper.updateById(user1);
System.out.println(i);
}
本文地址:https://blog.csdn.net/weixin_44109717/article/details/107351188
上一篇: MyBatisPlus代码生成器