您当前的位置: 首页 >  mybatis

陈橙橙丶

暂无认证

  • 2浏览

    0关注

    107博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

MybatisPlus(一):注解实现update,insert,delete操作自动填充createTime等字段

陈橙橙丶 发布时间:2021-03-31 15:51:31 ,浏览量:2

前言

我们会发现CRUD操作中,我们有大量的公共字段需要去更新,例如createTime、createUser等这些字段,下面就提供一共公共的方法来实现此功能

1、在实体类上添加TableField注解
 /**
     * 0-正常,1-删除
     */
    @ApiModelProperty(value="0-正常,1-删除")
	@TableField(fill = FieldFill.INSERT)
    private String delFlag;

我们来看看此注解的几个值

public enum FieldFill {
    DEFAULT,
    INSERT,
    UPDATE,
    INSERT_UPDATE;

    private FieldFill() {
    }
}

DEFAULT:默认不进行操作 INSERT:插入时进行操作 UPDATE:更新时进行操作 INSERT_UPDATE:在新增和修改时都进行操作。

重写MetaObjectHandler进行自定义实现
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
	//新增时操作
	@Override
	public void insertFill(MetaObject metaObject) {
		Integer userId = SecurityUtils.getUser().getId();
		LocalDateTime now = LocalDateTime.now();
		String delFlag = "0";
		//参数1、形参传入就行、参数2、实体类字段、参数3、填充值、参数4、值得类型
		this.strictInsertFill(metaObject, "createUser", ()->userId+"", String.class);
		this.strictInsertFill(metaObject, "createTime", ()->now, LocalDateTime.class);
		this.strictInsertFill(metaObject, "updateUser", ()->userId+"", String.class);
		this.strictInsertFill(metaObject, "updateTime", ()->now, LocalDateTime.class);
		this.strictInsertFill(metaObject, "delFlag", ()->delFlag,String.class);


	}
	//修改时操作
	@Override
	public void updateFill(MetaObject metaObject) {
		Integer userId = SecurityUtils.getUser().getId();
		LocalDateTime now = LocalDateTime.now();
		this.strictInsertFill(metaObject, "updateUser", ()->userId, Integer.class);
		this.strictInsertFill(metaObject, "updateTime", ()->now, LocalDateTime.class);
	}
}
注入自定义MetaObjectHandler交由Spring管理
@Configuration(proxyBeanMethods = false)
public class MybatisAutoConfiguration implements WebMvcConfigurer {

	@Bean
	public MetaObjectHandler metaObjectHandler(){
		return new MyMetaObjectHandler();
	}
}

我们新增一条数据尝试

在这里插入图片描述 成功!

到这里,感谢您的浏览,如果您发现有需要更改之处,还恳请您能够指出来,再次感谢!

关注
打赏
1648473527
查看更多评论
立即登录/注册

微信扫码登录

0.0395s