MybatisPlus自动填充功能+扫描resources下mapper文件

原理:
实现元对象处理器接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler
注解填充字段 @TableField(… fill = FieldFill.INSERT) 生成器策略部分也可以配置!

**

1.在Navicat工具user表中新添create_time,update_time 字段

**
在这里插入图片描述
2.在实体类User表添加刚才配置的字段

 @TableField(fill=FieldFill.INSERT) //驼峰命名
    private Date createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE) //驼峰命名
    private Date updateTime;

3.点进@TableField 看一下

    /**
     * 字段自动填充策略
     * <p>
     * 在对应模式下将会忽略 insertStrategy 或 updateStrategy 的配置,等于断言该字段必有值
     */
    FieldFill fill() default FieldFill.DEFAULT;

4.配置自定义实现类 MyMetaObjectHandler

  • 4.1方式一 注意:createTime->对应user表里的字段,updateTime一样
//让spring识别
@Slf4j
@Component  //一定不要忘记把处理器加入到ioc容器中
//MetaObjectHandler:原数据处理
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill.....");
        //String fieldName, Object fieldVal, MetaObject metaObject)
        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);
    }
}

MetaObjectHandler 接口默认开启插入,更新填充

    /**
     * 是否开启了插入填充
     */
    default boolean openInsertFill() {
        return true;
    }

    /**
     * 是否开启了更新填充
     */
    default boolean openUpdateFill() {
        return true;
    }

  • 4.2方式二 MybatisPlus官方使用
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill ....");
        this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
        // 或者
      //  this.strictInsertFill(metaObject, "createTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)
      //这里使用了lamda表达式 () -> 
        // 或者
       // this.fillStrategy(metaObject, "createTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        log.info("start update fill ....");
        this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)
        // 或者
      //  this.strictUpdateFill(metaObject, "updateTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)
        // 或者
       // this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
    }
}


5.配置MybatisPlusConfig

//注入spring容器
@MapperScan("com.lyj.demo.mapper")
@Configuration
public class MybatisPlusConfig {
 @Bean
    public MetaObjectHandler metaObjectHandler() {
        return new MyMetaObjectHandler();
    }
}

6.测试
在这里插入图片描述
7.检查错误 我们MyMetaObjectHandler 配置的是LocalDateTime

  • 处理一:实体类User表中用Date类型,配置类中用new Date()填充自动日期值
  • 处理二:实体类User表 中用LocalDateTime类型,配置类中用LocalDateTime填充自动日期值
    1.测试add方法
    在这里插入图片描述

2.测试update方法
在这里插入图片描述
再也不需要我们自己配置修改日期,不再需要在user构造方法里set注入new Date()了;
方法执行,它自动更新当前时间到数据库

8.注意事项

  • 填充原理是直接给entity的属性设置值!!! 注解则是指定该属性在对应情况下必有值,如果无值则入库会是null

  • MetaObjectHandler提供的默认方法的策略均为:如果属性有值则不覆盖,如果填充值为null则不填充

  • 字段必须声明TableField注解,属性fill选择对应策略,该声明告知Mybatis-Plus需要预留注入SQL字段

  • 填充处理器MyMetaObjectHandler在 Spring Boot 中需要声明@Component或@Bean注入

  • 要想根据注解FieldFill.xxx和字段名以及字段类型来区分必须使用父类的strictInsertFill或者strictUpdateFill方法

  • 不需要根据任何来区分可以使用父类的fillStrategy方法 update(T t,Wrapper
    updateWrapper)时t不能为空,否则自动填充失效

public enum FieldFill {
    /**
     * 默认不处理
     */
    DEFAULT,
    /**
     * 插入填充字段
     */
    INSERT,
    /**
     * 更新填充字段
     */
    UPDATE,
    /**
     * 插入和更新填充字段
     */
    INSERT_UPDATE
}

最后解决扫描resources下mapper文件

首先包结构如下图配置
在这里插入图片描述

在application.properties如下图配置即可:

#user表里的id字段配置
mybatis-plus.global-config.db-config.id-type=assign_id
mybatis-plus.mapper-locations=classpath*:/mapper/**/*.xml
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值