【SpringBoot3】Spring Boot 3.0 集成 Mybatis Plus

一、什么是 Mybatis Plus

MyBatis-Plus\](简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 ##### [](https://link.juejin.cn?target= "")特性 * **无侵入**:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑 * **损耗小**:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作 * **强大的 CRUD 操作**:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求 * **支持 Lambda 形式调用**:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错 * **支持主键自动生成**:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题 * **支持 ActiveRecord 模式**:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作 * **支持自定义全局通用操作**:支持全局通用方法注入( Write once, use anywhere ) * **内置代码生成器**:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用 * **内置分页插件**:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询 * **分页插件支持多种数据库**:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库 * **内置性能分析插件**:可输出 SQL 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询 * **内置全局拦截插件**:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作 #### [](https://link.juejin.cn?target= "")[](https://link.juejin.cn?target= "")二、Spring Boot 3.0 集成 Mybatis Plus **1、 添加依赖** ```xml mysql mysql-connector-java com.alibaba druid-spring-boot-starter 1.2.6 com.baomidou mybatis-plus-boot-starter 3.5.5 org.mybatis mybatis-spring 3.0.3 AI写代码 1234567891011121314151617181920 ``` > **注意:** SpringBoot 3.0 需要 mybatis-spring 3.0.X 版本,否则会报如下错误: > `Invalid value type for attribute 'factoryBeanObjectType''': java.lang.String` **2、配置数据源** ```ini # druid 数据源配置 spring.datasource.url=jdbc:mysql://localhost:3306/your_db?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.type=com.alibaba.druid.pool.DruidDataSource # 初始化大小,最小,最大 spring.datasource.druid.initial-size=5 spring.datasource.druid.min-idle=5 spring.datasource.druid.maxActive=20 # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 spring.datasource.druid.timeBetweenEvictionRunsMillis=60000 # 配置一个连接在池中最小生存的时间,单位是毫秒 spring.datasource.druid.minEvictableIdleTimeMillis=300000 spring.datasource.druid.validationQuery=SELECT 1 spring.datasource.druid.testWhileIdle=true spring.datasource.druid.testOnBorrow=false spring.datasource.druid.testOnReturn=false spring.datasource.druid.stat-view-servlet.allow=true spring.datasource.druid.web-stat-filter.enabled=true spring.datasource.druid.web-stat-filter.url-pattern=/druid/* spring.datasource.druid.filters=stat,wall,slf4j spring.datasource.druid.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000 # --- mybatis-plus start mybatis-plus.mapper-locations=classpath:/org/shi9/module/**/xml/*Mapper.xml # 关闭MP3.0自带的banner mybatis-plus.global-config.banner=false # 主键类型 0:"数据库ID自增",1:"该类型为未设置主键类型", 2:"用户输入ID",3:"全局唯一ID (数字类型唯一ID)", 4:"全局唯一ID UUID",5:"字符串全局唯一ID (idWorker 的字符串表示)"; mybatis-plus.global-config.db-config.id-type=ASSIGN_ID # 返回类型为Map,显示null对应的字段 mybatis-plus.configuration.call-setters-on-nulls=true # 这个配置会将执行的sql打印出来,在开发或测试的时候可以用 mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl # --- mybatis-plus end AI写代码 1234567891011121314151617181920212223242526272829303132333435 ``` **3、创建实体类和 Mapper** 创建你的实体类和对应的 Mapper 接口。MyBatis Plus 会自动扫描这些类并为你生成相应的 Mapper 和 SQL 语句。你也可以使用 MyBatis Plus 的 CRUD 操作来简化开发。 这里以`SysLog`为例 SysLogMapper.xml ```xml AI写代码 1234 ``` SysLogMapper.java ```java @Mapper public interface SysLogMapper extends BaseMapper { } AI写代码 1234 ``` **4、编写 Service 类** ```scala public interface ISysLogService extends IService { } @Service public class SysLogServiceImpl extends ServiceImpl implements ISysLogService { } AI写代码 12345678 ``` **5、编写测试类** ```less @Slf4j @SpringBootTest public class SysLogServiceTest { @Autowired private ISysLogService sysLogService; @Test public void findTotal(){ Long total = sysLogService.count(); System.out.println(total); } } AI写代码 123456789101112 ``` #### [](https://link.juejin.cn?target= "")[](https://link.juejin.cn?target= "")三、Mybatis Plus 查询示例 ##### [](https://link.juejin.cn?target= "")1、普通查询 以下是使用 MyBatis Plus 进行查询的示例: 1. **根据主键查询单个结果** 使用 `selectById` 方法查询单个结果: ```ini User user = userMapper.selectById(1L); AI写代码 1 ``` 2. **查询多条记录** 使用 `selectList` 方法查询多条记录: ```ini List users = userMapper.selectList(null); AI写代码 1 ``` 3. **使用 QueryWrapper 进行查询** 可以使用 `QueryWrapper` 对查询条件进行组装: ```ini QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", "John").lt("age", 30); List userList = userMapper.selectList(queryWrapper); AI写代码 123 ``` 4. **分页查询** 使用 `Page` 类进行分页查询: ```ini Page page = new Page<>(1, 10); // 第1页,每页显示10条记录 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", "John"); page.setFilter(queryWrapper); Page result = userMapper.selectPage(page, null); AI写代码 12345 ``` 5. **模糊查询** 使用 `like` 方法进行模糊查询: ```ini QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.like("name", "Jo"); List userList = userMapper.selectList(queryWrapper); AI写代码 123 ``` 6. **排序查询** 使用 `orderBy` 方法进行排序查询: ```ini QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.orderByDesc("age"); List userList = userMapper.selectList(queryWrapper); AI写代码 123 ``` 7. **聚合查询** 使用 `groupBy` 和 `sum`、`count` 等方法进行聚合查询: ```ini QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.groupBy("age"); Long totalCount = userMapper.selectSum(queryWrapper, "age"); AI写代码 123 ``` 8. **自定义 SQL** 使用 `@Select` 注解自定义 SQL 语句: ```less @Select("SELECT * FROM user WHERE age > #{age}") List selectUsersByAge(@Param("age") Integer age); AI写代码 12 ``` 这些示例只是 MyBatis Plus 提供的一些常见查询方法的冰山一角。MyBatis Plus 还提供了很多其他功能和扩展,可以根据需要进行配置和使用。同时,MyBatis Plus 还支持与其他组件的集成,例如分页插件、乐观锁插件等,可以帮助你更加高效地进行数据库操作。 ##### [](https://link.juejin.cn?target= "")2、分页查询 MyBatis Plus 支持分页功能,可以通过配置分页插件来实现。分页插件可以帮助我们自动处理分页相关的 SQL 语句,简化分页逻辑。以下是使用分页插件的步骤: **1、配置分页插件** ```java @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 配置分页插件 interceptor.addInnerInterceptor(new PaginationInnerInterceptor()); // 增加@Version乐观锁支持 interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); return interceptor; } AI写代码 123456789 ``` **2. 使用分页插件** 在 Mapper 接口或 XML 映射文件中使用分页插件提供的查询方法进行分页查询。例如: ```less @Select("SELECT * FROM user WHERE 1=1") Page selectUserPage(Page page); AI写代码 12 ``` 在查询方法上使用 `Page` 参数,MyBatis Plus 会自动处理分页相关的 SQL 语句,返回包含分页信息的 `Page` 对象。你可以根据需要配置查询条件、排序规则等。 **3. 处理分页结果** 根据返回的 `Page` 对象,你可以获取当前页的数据、总记录数、总页数等信息,进行相应的业务处理。例如: ```ini Page page = userMapper.selectUserPage(new Page<>(1, 10)); // 第1页,每页显示10条记录 List userList = page.getRecords(); // 当前页的数据列表 int totalCount = page.getTotal(); // 总记录数 int totalPage = page.getPages(); // 总页数 AI写代码 1234 ``` 通过这些步骤,你可以在 MyBatis Plus 中配置和使用分页插件,简化分页逻辑,提高开发效率。

相关推荐
whoops本尊1 小时前
Golang-Data race【AI总结版】
后端
墨守城规2 小时前
线程池用法及原理
后端
用户2190326527352 小时前
Spring Boot + Redis 注解极简教程:5分钟搞定CRUD操作
java·后端
计算机学姐2 小时前
基于php的旅游景点预约门票管理系统
开发语言·后端·mysql·php·phpstorm
用户908324602732 小时前
SpringBoot集成DeepSeek
后端
无限大62 小时前
为什么"云计算"能改变世界?——从本地计算到云端服务
后端
哈哈老师啊2 小时前
Springboot校园订餐管理系统k2pr7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
JIngJaneIL2 小时前
基于java+ vue学生选课系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
喵叔哟2 小时前
10.消息队列集成
后端·服务发现