MybatisPlus 自动填充的实现

2022-10-18,,

这篇文章主要介绍了MybatisPlus 自动填充的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、设置填充时机

使用下面的注解设置填充的时机,例如insert 、update语句

@TableField(fill = FieldFill.INSERT)

有下面4种规则

源码

/**
 * 字段填充策略枚举类
 *
 * <p>
 * 判断注入的 insert 和 update 的 sql 脚本是否在对应情况下忽略掉字段的 if 标签生成
 * <if test="...">......</if>
 * 判断优先级比 {@link FieldStrategy} 高
 * </p>
 *
 * @author hubin
 * @since 2017-06-27
 */
public enum FieldFill {
  /**
   * 默认不处理
   */
  DEFAULT,
  /**
   * 插入时填充字段
   */
  INSERT,
  /**
   * 更新时填充字段
   */
  UPDATE,
  /**
   * 插入和更新时填充字段
   */
  INSERT_UPDATE
}

二、设置填充的值

创建一个类实现mp提供的MetaObjectHandler接口

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
  @Override
  public void insertFill(MetaObject metaObject) {
    setFieldValByName("字段名,例如User的createTime", LocalDateTime.now(),metaObject);
  }

  @Override
  public void updateFill(MetaObject metaObject) {
    setFieldValByName("字段名,例如User的updateTime",LocalDateTime.now(),metaObject);
  }
}

注意请将中文去掉换成自己实体对象的字段名

测试代码:

User user = new User();
user.setName("张三");
user.setAge(12);
user.setAge(12);
user.setId(11111111111L);
user.setEmail("someone@qq.com");
user.setManagerId(1087982257332887553L);
int insert = userMapper.insert(user);
System.out.println("插入"+insert);

检测表中数据:

说明成功

优化填充规则

案例代码:

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.time.LocalDateTime;

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
  @Override
  public void insertFill(MetaObject metaObject) {
    boolean createTime = metaObject.hasSetter("createTime");//如果有这个字段返回true
    if (createTime) {//如果字段不存在则不进行下面的填充
      setFieldValByName("createTime", LocalDateTime.now(), metaObject);
    }
  }

  @Override
  public void updateFill(MetaObject metaObject) {
    Object updateTime = getFieldValByName("updateTime", metaObject);
    if (null == updateTime) { //没有设置updateTime值则进行填充如果有设置值则不进行填充
      setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
    }
  }
}

到此这篇关于MybatisPlus 自动填充的实现的文章就介绍到这了,更多相关MybatisPlus 自动填充内容请搜索北冥有鱼以前的文章或继续浏览下面的相关文章希望大家以后多多支持北冥有鱼!

您可能感兴趣的文章:

  • MybatisPlus 插入或更新数据时自动填充更新数据解决方案
  • MyBatisPlus中使用@TableField完成字段自动填充的操作
  • Mybatisplus自动填充实现方式及代码示例
  • mybatisPlus自动填充更新时间的示例代码

《MybatisPlus 自动填充的实现.doc》

下载本文的Word格式文档,以方便收藏与打印。