以下是一些常用的 MyBatis-Plus 扩展工具类和方法,按功能分类:
## 一、基础工具类
| 工具类 | 方法 | 说明 |
|--------|------|------|
| **StringUtils** | `isEmpty/isNotEmpty` | 字符串判空 |
| | `isBlank/isNotBlank` | 字符串判空(包含空格) |
| | `camelToUnderline` | 驼峰转下划线 |
| | `capitalizeFirst` | 首字母大写 |
| **CollectionUtils** | `isEmpty/isNotEmpty` | 集合判空 |
| | `listToMap` | List转Map |
| **ObjectUtils** | `isNull/isNotNull` | 对象判空 |
| **DateUtils** | `format` | 日期格式化 |
| | `parse` | 日期解析 |
## 二、SQL 相关工具
| 工具类 | 方法 | 说明 |
|--------|------|------|
| **SqlUtils** | `removeBreakingWhitespace` | 去除SQL中多余空格 |
| | `getWhere` | 获取WHERE条件 |
| **SqlInjectionUtils** | `check` | SQL注入检查 |
| **ScriptUtils** | `convert` | 脚本转换 |
## 三、Wrapper 条件构造器
| 方法 | 示例 | 说明 |
|------|------|------|
| **QueryWrapper** | `.eq("name", "张三")` | 等于条件 |
| | `.like("name", "张")` | 模糊查询 |
| | `.in("id", [1,2,3])` | IN查询 |
| | `.orderByAsc("create_time")` | 排序 |
| **LambdaQueryWrapper** | `.eq(User::getName, "张三")` | Lambda表达式条件 |
| | `.between(User::getAge, 18, 30)` | 范围查询 |
| **UpdateWrapper** | `.set("name", "李四")` | 设置更新值 |
| | `.setSql("balance = balance + 100")` | 设置SQL表达式 |
## 四、分页相关
| 类/方法 | 说明 |
|---------|------|
| **Page<T>** | 分页参数封装类 |
| `PaginationInterceptor` | 分页拦截器(旧版) |
| `MybatisPlusInterceptor` | 分页拦截器(新版) |
| `PaginationInnerInterceptor` | 分页内部拦截器 |
## 五、代码生成器
| 类 | 方法/配置 | 说明 |
|----|----------|------|
| **AutoGenerator** | `.setDataSource()` | 数据源配置 |
| | `.setGlobalConfig()` | 全局配置 |
| | `.setPackageInfo()` | 包配置 |
| | `.setStrategy()` | 策略配置 |
| | `.setTemplateEngine()` | 模板引擎 |
| **FastAutoGenerator** | 链式配置 | 快速代码生成器 |
## 六、枚举处理
| 类/注解 | 说明 |
|---------|------|
| **@EnumValue** | 标记枚举值(数据库存储) |
| `EnumTypeHandler` | 枚举类型处理器 |
| **IEnum<T>** | 枚举接口 |
## 七、数据填充
| 类/注解 | 说明 |
|---------|------|
| **MetaObjectHandler** | 元对象处理器接口 |
| `insertFill()` | 插入时自动填充 |
| `updateFill()` | 更新时自动填充 |
| **@TableField(fill = ...)** | 字段填充策略 |
## 八、ID生成器
| 类 | 说明 |
|----|------|
| `DefaultIdentifierGenerator` | 默认ID生成器 |
| `Snowflake` | 雪花算法 |
| **IdentifierGenerator** | ID生成器接口(可自定义) |
## 九、多租户支持
| 类/配置 | 说明 |
|---------|------|
| `TenantLineInnerInterceptor` | 多租户拦截器 |
| `TenantLineHandler` | 租户处理器接口 |
| `@SqlParser(filter = true)` | SQL解析器注解 |
## 十、性能分析
| 类/配置 | 说明 |
|---------|------|
| `PerformanceInterceptor` | 性能分析拦截器(旧版) |
| `IllegalSQLInnerInterceptor` | SQL性能分析拦截器 |
## 十一、动态表名
| 类 | 说明 |
|----|------|
| `DynamicTableNameInnerInterceptor` | 动态表名拦截器 |
| `TableNameHandler` | 表名处理器接口 |
## 十二、其他实用工具
| 工具类 | 方法 | 说明 |
|--------|------|------|
| **Db** | `.list()` | 执行SQL查询 |
| | `.save()` | 执行SQL插入 |
| | `.update()` | 执行SQL更新 |
| | `.delete()` | 执行SQL删除 |
| **Condition** | `.create()` | 创建Wrapper条件 |
| | `.isSql()` | 是否SQL条件 |
| **Constants** | 常量类 | 存放框架常量 |
| **IdWorker** | `getId()` | 分布式ID生成 |
| | `getTimeId()` | 时间ID生成 |
## 使用示例
```java
// 1. QueryWrapper 示例
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.eq("status", 1)
.like("username", "admin")
.orderByDesc("create_time");
// 2. LambdaQueryWrapper 示例
LambdaQueryWrapper<User> lambdaWrapper = new LambdaQueryWrapper<>();
lambdaWrapper.eq(User::getStatus, 1)
.between(User::getAge, 18, 60);
// 3. 分页查询
Page<User> page = new Page<>(1, 10);
page.setRecords(userMapper.selectPage(page, wrapper).getRecords());
// 4. 自动填充
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());
}
@Override
public void updateFill(MetaObject metaObject) {
this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
}
}
```
## 版本说明
- **3.x版本**:使用 `MybatisPlusInterceptor` + 各种内部拦截器
- **3.4.0+**:推荐使用 `FastAutoGenerator` 代码生成器
- **注意**:部分工具类在不同版本中可能有差异
以上是 MyBatis-Plus 常用的扩展工具类和方法,实际使用时应根据具体版本参考官方文档。
- 环境配置
- 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 数据传输层 的区别
