本文为Mybatis Plus系列文章的第9篇,前8篇拜访地址如下:

  • 小书MybatisPlus第1篇-整合SpringBoot疾速开始增删改查
  • 小书MybatisPlus第2篇-条件结构器的利用及总结
  • 小书MybatisPlus第3篇-自定义SQL
  • 小书MybatisPlus第4篇-表格分页与下拉分页查问
  • 小书MybatisPlus第5篇-Active Record模式精讲
  • 小书MybatisPlus第6篇-主键生成策略精讲
  • 小书MybatisPlus第7篇-代码生成器的原理精讲及应用办法
  • 小书MybatisPlus第8篇-逻辑删除实现及API细节精讲

一、填充字段解决

需要案例:在插入数据的时候主动填充createTime和updateTime为以后插入数据的工夫,在数据更新的时候批改updateTime为批改数据的工夫。不须要人为的手动赋值。

  • 在数据库表层面须要先增加2个日期类型的字段create_tme和update_time

  • 应用@TableField注解标记实体类中的哪些字段须要填充:
@Datapublic class User {    private Long id;    private String name;    private Integer age;    private String email;    @TableField(fill = FieldFill.INSERT)    private Date createTime;    @TableField(fill = FieldFill.INSERT_UPDATE)    private Date updateTime;}

FieldFill是一个枚举,用于指定在何种状况下会主动填充,有如下几种可选值:

  • DEFAULT:默认不解决
  • INSERT:插入时主动填充字段
  • UPDATE:更新时主动填充字段
  • INSERT_UPDATE:插入和更新时主动填充字段

二、自定义填充默认数值

编写公共字段填充处理器类,该类继承了MetaObjectHandler类,重写 insertFill和updateFill办法,咱们在这两个办法中获取须要填充的字段以及默认填充的值。

  • 填充处理器MyMetaObjectHandler在Spring Boot中须要申明@Component或@Bean注入
  • strictInsertFill和strictUpdateFill办法第二个参数写的是实体类里的属性名,不是对应数据库字段名。
@Componentpublic class MyMetaObjectHandler implements MetaObjectHandler {     @Override    public void insertFill(MetaObject metaObject) {        this.strictInsertFill(metaObject, "createTime", Date.class, new Date());        this.strictInsertFill(metaObject, "updateTime", Date.class, new Date());    }     @Override    public void updateFill(MetaObject metaObject) {        this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date());    }}

如果是3.3.0前面的版本,比方3.3.1.8,也能够改用上面更简略的写法(3.3.0不要用该办法,有bug)

@Componentpublic class MyMetaObjectHandler implements MetaObjectHandler {     @Override    public void insertFill(MetaObject metaObject) {        this.fillStrategy(metaObject, "createTime", new Date());        this.fillStrategy(metaObject, "updateTime", new Date());    }     @Override    public void updateFill(MetaObject metaObject) {        this.fillStrategy(metaObject, "updateTime", new Date());    }}

在一些比拟旧的版本,为填充字段设置值的API如下,3.3.0之后曾经不倡议应用

this.setFieldValByName("createTime",new Date(),metaObject); this.setFieldValByName("updateTime",new Date(),metaObject);

三、开始测试

  • 插入一条数据,留神咱们没有为createTime和updateTime赋值
@Testpublic void testInsert() {  User user = new User();  user.setName("字母哥");  user.setAge(18);  userMapper.insert(user);}

然而运行的后果是:createTime和updateTime被主动赋值

  • 依据Id更新一条数据,留神咱们没有为updateTime赋值
@Testpublic void testUpdate() {  User user = new User();  user.setId(1287387821681790977L);  user.setName("字母哥&curry");  user.setAge(18);  userMapper.updateById(user);}

然而运行的后果是:updateTime在执行数据记录批改操作时被主动赋值

欢送关注我的博客,外面有很多精品合集

  • 本文转载注明出处(必须带连贯,不能只转文字):字母哥博客。

感觉对您有帮忙的话,帮我点赞、分享!您的反对是我不竭的创作能源! 。另外,笔者最近一段时间输入了如下的精品内容,期待您的关注。

  • 《手摸手教你学Spring Boot2.0》
  • 《Spring Security-JWT-OAuth2一本通》
  • 《实战前后端拆散RBAC权限管理系统》
  • 《实战SpringCloud微服务从青铜到王者》
  • 《VUE深入浅出系列》