mybatis-plus自动填充

前言

这是我在这个网站整理的笔记,关注我,接下来还会持续更新。 作者:神的孩子都在歌唱

mybatis-plus自动填充

大家做设计数据表的时候,基本上都会有del_flag,create_time, update_time,这三个字段,这也是表必备的三字段,可是有一个问题,我们每次做增改的时候都要写代码去定义一下这些字段的值,这样会很麻烦,目前有两种方法解决

  1. sql可以自定义默认值,也就是在建表的时候给字段设定默认值就可以了,下面以pgsql为例
  1. 在代码里面写一个自动填充的功能,相当于是写一个公共方法,下面参考mybatis-plus

mybati-plus帮我们实现了底层逻辑,我们只需要自定义实现类MyMetaObjectHandler就可以了

mybatis-plush官网

自定义 MyMetaObjectHandler

java 复制代码
@Slf4j
public class CreateAndUpdateMetaObjectHandler implements MetaObjectHandler {

	@Override
	public void insertFill(MetaObject metaObject) {
		try {
			//根据属性名字设置要填充的值
			if (metaObject.hasGetter("createTime")) {
                this.setFieldValByName("createTime", new Date(), metaObject);
			}

            //根据属性名字设置要填充的值
            if (metaObject.hasGetter("delFlag")) {
                this.strictInsertFill(metaObject,"delFlag", String.class, "0");
            }

		} catch (Exception e) {
			throw new ServiceException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
		}
	}

	@Override
	public void updateFill(MetaObject metaObject) {
		try {
			if (metaObject.hasGetter("updateTime")) {
				this.setFieldValByName("updateTime", new Date(), metaObject);
			}
		} catch (Exception e) {
			throw new ServiceException("自动注入异常 => " + e.getMessage(), HttpStatus.HTTP_UNAUTHORIZED);
		}
	}



}

然后需要创建一个mybatis-plus配置类

java 复制代码
@EnableTransactionManagement(proxyTargetClass = true)
@Configuration
// 指定要扫描的Mapper类的包的路径
@MapperScan("${mybatis-plus.mapperPackage}")
public class MybatisPlusConfig {


	/**
	 * 元对象字段填充控制器
	 * https://baomidou.com/guide/auto-fill-metainfo.html
	 */
	@Bean
	public MetaObjectHandler metaObjectHandler() {
		return new CreateAndUpdateMetaObjectHandler();
	}



}

然后再注解填充字段

作者:神的孩子都在歌唱

本人博客:https://blog.csdn.net/weixin_46654114

转载说明:务必注明来源,附带本人博客连接。

相关推荐
C+-C资深大佬10 小时前
SSM 框架(Spring + SpringMVC + MyBatis)
java·spring·mybatis
二王一个今14 小时前
springboot security 权限控制---循环依赖问题
mybatis
落木萧萧82520 小时前
为什么我把 MyBatisGX 设计成现在这样
mybatis·orm
代码旅人ing20 小时前
Redis+Spring+MyBatis + 微服务 + 消息队列核心知识点(面试高频题目合集)
redis·spring·mybatis·java-rabbitmq
Devin~Y20 小时前
大厂Java面试实录:Spring Boot/Cloud、Kafka、Redis、K8s 可观测性 + RAG/Agent(小Y翻车版)
java·spring boot·redis·spring cloud·kafka·kubernetes·mybatis
ppandss121 小时前
JavaWeb从0到1-DAY11-MyBatis入门
java·tomcat·mybatis
JAVA面经实录9171 天前
MyBatis面试题库
java·mybatis
杨运交1 天前
[022][数据模块]基于雪花算法的 MyBatis-Plus 主键生成器设计与实现
mybatis
Mahir082 天前
MyBatis 深度解密:从执行流程到底层原理全解
java·后端·面试·mybatis
Mahir082 天前
MyBatis 分页与插件深度解密:从插件机制到三大分页方案原理全解
java·后端·mybatis·mybatis-plus·大厂面试题