您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这篇文章运用简单易懂的例子给大家介绍使用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 如何实现自动填充功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。