MybatisPlus 自动填充 MybatisPlus 自动填充的实现
诗水人间 人气:0想了解MybatisPlus 自动填充的实现的相关内容吗,诗水人间在本文为您仔细讲解MybatisPlus 自动填充的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点: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); } } }
加载全部内容