# MyBatis-Plus 常用功能一览表
**MyBatis-Plus是MyBatis的功能增强框架,在保留MyBatis所有能力的基础上,提供了更丰富的开箱即用功能和便捷的CRUD操作,显著减少了传统MyBatis的样板代码。**
以下是 MyBatis-Plus 在 Java 项目中的核心功能分类及说明:
## 📋 核心功能总览
| 功能模块 | 主要功能 | 作用说明 | 使用示例/注解 |
|---------|---------|---------|-------------|
| **核心增强** | 通用Mapper | 内置常用CRUD方法,无需编写XML | `BaseMapper<T>` |
| | 通用Service | Service层快速开发接口 | `IService<T>`, `ServiceImpl` |
| | 条件构造器 | 动态SQL条件构建 | `QueryWrapper`, `UpdateWrapper` |
| **代码生成** | 代码生成器 | 自动生成Entity、Mapper、Service等 | `AutoGenerator` |
| **CRUD扩展** | 主键生成策略 | 多种主键生成方式 | `@TableId(type = IdType.AUTO)` |
| | 字段自动填充 | 自动填充创建/修改时间等字段 | `@TableField(fill = FieldFill.INSERT)` |
| | 逻辑删除 | 软删除实现,数据不物理删除 | `@TableLogic` |
| **查询增强** | 分页插件 | 物理分页支持 | `PaginationInterceptor`, `Page<T>` |
| | 性能分析插件 | SQL执行性能分析 | `PerformanceInterceptor` |
| | 乐观锁插件 | 数据版本控制,防并发冲突 | `@Version`, `OptimisticLockerInterceptor` |
| **扩展插件** | 多租户插件 | SaaS系统数据隔离支持 | `TenantLineInnerInterceptor` |
| | 动态表名插件 | 动态切换表名 | `DynamicTableNameInnerInterceptor` |
| **其他特性** | 枚举处理 | 数据库字段与枚举自动映射 | `@EnumValue` |
| | 序列化优化 | 自定义类型处理器 | `@TableField(typeHandler = ...)` |
---
## 🛠️ 详细功能说明
### 1. **核心CRUD功能**
| 功能 | 说明 | 代码示例 |
|------|------|----------|
| **通用Mapper** | 提供开箱即用的17个基础方法 | ```UserMapper extends BaseMapper<User>``` |
| **条件构造器** | Lambda表达式构建查询条件 | ```wrapper.eq(User::getName, "张三").ge(User::getAge, 18)``` |
| **ActiveRecord** | 实体类直接操作数据库(可选) | ```user.insert(); user.updateById();``` |
### 2. **代码生成器配置**
```java
AutoGenerator mpg = new AutoGenerator();
// 全局配置
mpg.setGlobalConfig(globalConfig);
// 数据源配置
mpg.setDataSource(dataSourceConfig);
// 包配置
mpg.setPackageInfo(packageConfig);
// 策略配置
mpg.setStrategy(strategyConfig);
mpg.execute();
```
### 3. **常用注解详解**
| 注解 | 作用 | 示例 |
|------|------|------|
| `@TableName` | 指定表名 | `@TableName("sys_user")` |
| `@TableId` | 指定主键及策略 | `@TableId(type = IdType.ASSIGN_ID)` |
| `@TableField` | 字段映射配置 | `@TableField(value = "email", fill = FieldFill.INSERT)` |
| `@Version` | 乐观锁版本字段 | `@Version private Integer version;` |
| `@TableLogic` | 逻辑删除标识 | `@TableLogic private Integer deleted;` |
### 4. **主键生成策略**
| 策略类型 | 说明 | 适用场景 |
|---------|------|----------|
| `AUTO` | 数据库自增 | MySQL, PostgreSQL |
| `NONE` | 无状态 | 手动赋值 |
| `INPUT` | 用户输入 | 自定义ID |
| `ASSIGN_ID` | MP分配ID(雪花算法) | 分布式系统 |
| `ASSIGN_UUID` | 分配UUID | 需要UUID的场景 |
### 5. **插件配置示例**
```yaml
# application.yml 配置示例
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl # SQL日志
global-config:
db-config:
logic-delete-field: deleted # 全局逻辑删除字段
logic-delete-value: 1 # 删除值
logic-not-delete-value: 0 # 未删除值
```
### 6. **Wrapper条件构造示例**
| 查询类型 | 示例代码 |
|----------|----------|
| **等值查询** | `wrapper.eq("name", "张三")` |
| **范围查询** | `wrapper.between("age", 18, 30)` |
| **模糊查询** | `wrapper.like("name", "张%")` |
| **排序** | `wrapper.orderByDesc("create_time")` |
| **子查询** | `wrapper.inSql("dept_id", "select id from dept where status=1")` |
---
## 📊 功能选择建议
| 项目类型 | 推荐功能 |
|----------|----------|
| **快速原型** | 代码生成器 + 通用Mapper + 基础CRUD |
| **企业后台** | 分页插件 + 字段填充 + 逻辑删除 |
| **SaaS系统** | 多租户插件 + 数据权限控制 |
| **高并发** | 乐观锁插件 + 性能分析插件 |
| **微服务** | 分布式ID + 枚举处理 + 序列化优化 |
---
## ⚡ 最佳实践提示
1. **性能考虑**:生产环境关闭性能分析插件
2. **安全考虑**:使用Lambda表达式防止SQL注入(`QueryWrapper<User>.lambda()`)
3. **版本兼容**:注意MyBatis-Plus与Spring Boot的版本匹配
4. **自定义扩展**:复杂SQL建议仍使用XML映射文件
5. **批量操作**:使用`Service`层的`saveBatch()`等方法优化批量操作
---
通过合理使用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 数据传输层 的区别
