MyBatis-Plus (MP) 在原生 MyBatis 的基础上,提供了非常多实用的工具类,极大地简化了业务层(Service)和持久层(Mapper)之外的数据操作。
以下是 MyBatis-Plus 中最常用的 **4 大核心工具类**及其高频方法汇总:
### MyBatis-Plus 常用工具类汇总表
| **工具类** | **核心作用** | **高频方法** | **功能描述** |
| --- | --- | --- | --- |
| **`Db`** (静态 CRUD) | **不依赖 Service** 直接操作数据库 | `Db.getById(id, Entity.class)` | 根据 ID 查询(静态方法调用) |
| | | `Db.list(wrapper)` | 根据条件查询列表 |
| | | `Db.saveBatch(list)` | **批量插入**数据(非常实用) |
| | | `Db.update(wrapper)` | 链式更新数据 |
| **`Wrappers`** | **条件构造器**快速生成 | `Wrappers.lambdaQuery()` | 生成 LambdaQueryWrapper,防误写 |
| | | `Wrappers.lambdaUpdate()` | 生成 LambdaUpdateWrapper |
| | | `Wrappers.emptyWrapper()` | 获取一个空的条件构造器 |
| **`ChainQuery`** | **链式查询** | `ChainQuery.lambdaQuery(mapper)` | 开启链式查询:`.eq().list()` |
| **`CollectionUtils`** | **集合增强工具** | `CollectionUtils.isEmpty()` | 判断集合是否为空(类似 Spring 的) |
| | | `CollectionUtils.newHashMap()` | 快速创建具有初始容量的 Map |
* * *
### 1\. 深度解析:最强工具类 `Db` (静态助手)
这是 MP 3.5.0+ 极力推荐的工具类。它允许你在任何地方(哪怕没有注入 Service)通过静态方式操作数据库,完美解决 **Service 循环注入** 的问题。
**代码演示:**
Java
~~~
// 无需 @Autowired 注入 Service,直接一行代码查询
User user = Db.getById(1L, User.class);
// 批量保存
List<User> list = new ArrayList<>();
Db.saveBatch(list);
~~~
* * *
### 2\. 链式编程工具 (Chain)
MyBatis-Plus 提供了非常优雅的链式调用,让代码读起来像英语句子。
| **类型** | **方法** | **示例** |
| --- | --- | --- |
| **链式查询** | `lambdaQuery()` | `this.lambdaQuery().eq(User::getName, "张三").list();` |
| **链式更新** | `lambdaUpdate()` | `this.lambdaUpdate().set(User::getAge, 18).eq(User::getId, 1).update();` |
* * *
### 3\. 条件构造器常用方法汇总表
当你使用 `Wrappers.lambdaQuery()` 时,以下方法是最常用的:
| **方法** | **说明** | **SQL 对应** |
| --- | --- | --- |
| **`.eq()`** | 等于 (Equal) | `=` |
| **`.ne()`** | 不等于 (Not Equal) | `<>` |
| **`.gt()` / `.ge()`** | 大于 / 大于等于 | `>` / `>=` |
| **`.lt()` / `.le()`** | 小于 / 小于等于 | `<` / `<=` |
| **`.like()`** | 模糊查询 | `LIKE '%val%'` |
| **`.in()`** | 范围查询 | `IN (v1, v2, ...)` |
| **`.orderByDesc()`** | 倒序排序 | `ORDER BY column DESC` |
| **`.last()`** | 无视规则,直接拼接到 SQL 最后 | `LIMIT 1` |
* * *
### 💡 核心开发建议
1. **优先使用 Lambda:** 永远使用 `lambdaQuery()` 或 `LambdaQueryWrapper`,不要使用字符串字段名(如 `"user_id"`),防止数据库字段改名导致代码报错。
2. **避免 Service 循环依赖:** 如果 Service A 需要调用 Service B,同时 Service B 又需要调用 Service A,请直接使用 `Db` 静态工具类打破循环。
3. **批量操作:** 对于超过 10 条的数据操作,务必使用 `saveBatch` 或 `updateBatchById`,MP 内部做了性能优化。
- 环境配置
- window怎么配置java环境变量?
- SQL学习
- 字段类型
- 1、 所有可声明的字段类型
- 2、常用的可声明的字段类型
- 创建表和表内字段
- 1、整个创建表语句
- 2、设置id主键
- 3、设置业务主键,唯一索引
- 4、设置业务字段
- 5、普通索引
- 6、唯一索引与普通索引的区别
- 7、表的引擎、字符集、排序规则和注释的设置
- Java基础语法
- 数据类型
- Java中的数据类型
- LocalDate
- 常用的数据类型
- Java 常用数据类型方法
- Java中数组、list、Map、HashMap
- 如何用Map来优化那些复杂的“双重 for 循环”查询?
- Java 8 中steam()操作流
- Java中HashMap和JSON
- Java中的JSONObject
- 工具类
- Java 常用工具类
- Arrays工具类
- Java 时间工具类
- 泛型
- Java中泛型概念
- Java中的泛型容器
- 泛型参数与函数参数的区别
- 推断出泛型实参
- Lambda表达式
- 数据分层
- 异常处理
- Java8 异常处理类总结表
- MyBatis-Plus 常用异常类总结表
- Java高级特性
- Maven
- jib-maven-plugin
- 什么是Spring Boot 的 parent pom?
- maven中各个生命周期的含义
- Spring Boot
- maven与spring boot 的关系
- Java中的连接池
- Spring JDBC
- Spring JDBC的概念
- JdbcTemplate常用的方法
- Spring中Bean的概念
- Spring中的抽象,通俗解释一下
- Spring中的事物
- Spring中的事物,通俗解释一下
- Spring中的事物抽象,常见的有哪些,列举一下
- Spring中常用的事物场景有哪些,列举一下
- Spring事务管理有哪些注解?
- Spring中使用事物处理订单的案例,列举说明一下
- Spring中声明式事务、分布式事务以及编程式事务的区别,列举一下
- 配置文件
- application-properties配置文件
- Spring Boot 的启动
- spring boot项目如何启动?
- 列举一下Spring Boot的启动过程
- SpringApplication.run方法
- Spring Boot 启动时有哪些接口?
- CommandLineRunner
- Spring Boot 的常用注解
- 系统注解
- 表格:系统注解
- @Override
- @Deprecated
- @SuppressWarnnings
- 使用在类名上的注解
- 表格:使用在类名上的注解
- @RestController
- @Controller
- @Service
- @Repository
- @Component
- @Configuration
- @Resource
- @Autowired
- @RequestMapping
- @GetMapping
- @PostMapping
- @Transactional
- @Qualifier
- 使用在方法上的注解
- 表格:使用在方法上的注解
- @RequestBody
- @PathVariable
- @Bean
- @ResponseBody
- @PreAuthorize
- 其他常用注解
- 表格:其他常用注解
- @EnableAutoConfiguration
- @SpringBootApplication
- @EnableScheduling
- @EnableAsync
- @ComponentScan
- @Aspec
- @ControllerAdvice
- @ExceptionHandler
- @Value
- @ConfigurationProperties
- @EnableConfigurationProperties
- @MapperScan
- @ApiOperation
- @Produces
- Validator验证的常用注解
- spring IoC容器
- Spring IoC容器依赖注入实现方式
- 常用依赖
- RESTEasy
- resteasy简介
- RESTEasy框架(依赖)的功能和常用注解
- MyBatis
- 简介
- paginationInterceptor
- @TableName
- @TableId
- @Param
- MyBatis-Plus
- MyBatis-Plus简介
- MyBatis-Plus的工具类
- Mybatis-Plus扩展的工具类和方法
- MyBatis-Plus中最常用的工具类方法
- MyBatis-Plus 中最常用的 4 大核心工具类
- Wrapper条件构造器
- Wrapper条件构造器详解
- Wrapper条件构造器eq等方法的参数说明
- LambdaQueryWrapper与QueryWrapper
- 日期格式是否必须转换
- Lombok
- Lombok作用详解
- @Data
- @Slf4j
- @Builder
- @EqualsAndHashCode
- @Accessors
- Jackson
- Jackson简介
- @JsonFormat
- Jackson高效地在 HashMap 和 JSON 字符串之间进行相互转换
- Hutool
- Hutool简介
- hutool依赖常用的方法
- fastjson2
- fastjson2简介
- UrlBasedCorsConfigurationSource
- 生态相关
- JBoss 社区
- 支付系统
- 1. 初始化mysql数据库流程
- 2. 初始化redis数据库的流程
- 3. 初始化rabbitmq服务
- 环球置业
- 1.模块目录结构分析
- 2. DTO(数据传输层)的核心作用
- 3. VO(视图对象层)
- 4. VO(视图对象层)和 DTO 数据传输层 的区别
