背景
当我们使用RuoYi-Cloud框架来开发自己的项目时往往会新增一个模块来实现自己的业务需求,但是习惯了MP的开发会觉得Mybatis开发起来就有些繁琐,于是就想着在自己的模块中集成Mybatis-Plus。
新增模块
新增模块的目的就是让整个模块看起来更加的清楚明了,详细的新增模块步骤官网是比较清楚的,详见后台手册 | RuoYi
集成MP
根pom进行依赖声明
<mybatis-plus.version>3.5.1</mybatis-plus.version>
<!-- mybatis-plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
模块引用
在ruoyi-common-core进行引用
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
</dependency>
进行MP的配置
配置文件路径 ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/config/MybatisPlusConfig.java
内容如下:
package com.ruoyi.common.core.config;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;
@EnableTransactionManagement(proxyTargetClass = true)
@Configuration
public class MybatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
// 分页插件
interceptor.addInnerInterceptor(paginationInnerInterceptor());
// 乐观锁插件
interceptor.addInnerInterceptor(optimisticLockerInnerInterceptor());
// 阻断插件
interceptor.addInnerInterceptor(blockAttackInnerInterceptor());
return interceptor;
}
/**
* 分页插件,自动识别数据库类型 https://baomidou.com/guide/interceptor-pagination.html
*/
public PaginationInnerInterceptor paginationInnerInterceptor() {
PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
// 设置数据库类型为mysql
paginationInnerInterceptor.setDbType(DbType.MYSQL);
// 设置最大单页限制数量,默认 500 条,-1 不受限制
paginationInnerInterceptor.setMaxLimit(-1L);
return paginationInnerInterceptor;
}
/**
* 乐观锁插件 https://baomidou.com/guide/interceptor-optimistic-locker.html
*/
public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor() {
return new OptimisticLockerInnerInterceptor();
}
/**
* 如果是对全表的删除或更新操作,就会终止该操作 https://baomidou.com/guide/interceptor-block-attack.html
*/
public BlockAttackInnerInterceptor blockAttackInnerInterceptor() {
return new BlockAttackInnerInterceptor();
}
//====================================================自动填充开始===================================================
/**
* 更新时插入数据
*
* @param metaObject 元对象
*/
// @Override
// public void insertFill(MetaObject metaObject) {
// System.out.println("******************执行了自动填充******************");
// setFieldValByName("createTime", new Date(), metaObject);
// setFieldValByName("updateTime", new Date(), metaObject);
// setFieldValByName("isDel", 0, metaObject);
// setFieldValByName("createBy", SecurityUtils.getUsername(), metaObject);
// setFieldValByName("updateBy", SecurityUtils.getUsername(), metaObject);
// }
/**
* 更新时插入数据
*
* @param metaObject 元对象
*/
// @Override
// public void updateFill(MetaObject metaObject) {
// System.out.println("******************执行了自动填充******************");
// setFieldValByName("updateTime", new Date(), metaObject);
// setFieldValByName("updateBy", SecurityUtils.getUsername(), metaObject);
// }
//====================================================自动填充结束===================================================
}
引入
这里也不太清楚,和远程调用一样需要写入到这里
别忘了在配置中心中将原来的Mybatis配置改为Mybatis-plus
这里system模块不改的话启动会报错
项目启动测试
MP接口测试
调用结果
至此我们的项目集成MP就结束了,感谢你看到这里。