
MyBatis-Plus 作为 MyBatis 的增强工具,秉持 "只做增强不做改变" 的理念,旨在简化开发流程、提升开发效率。它不仅保留了 MyBatis 的原有功能,还通过一系列便捷特性让数据库操作变得更加轻松。
快速入门:从依赖到 CRUD
使用 MyBatis-Plus 的第一步是引入官方提供的启动依赖mybatis-plus-spring-boot3-starter
,这一个依赖便集成了 MyBatis 和 MyBatis-Plus 的所有功能,并实现了自动装配。接下来,定义 Mapper 接口时只需继承BaseMapper<T>
,即可获得基础的 CRUD 操作能力,无需编写繁琐的 SQL 语句。例如,UserMapper
继承BaseMapper<User>
后,就能直接使用selectById
、insert
、updateById
等方法。
实体类与数据库的映射:注解的力量
MyBatis-Plus 通过扫描实体类并基于反射获取数据库表信息。默认规则是将类名驼峰转下划线作为表名,名为id
的字段作为主键,变量名驼峰转下划线作为表字段名。当默认规则不适用时,可通过注解进行灵活配置:
@TableName
用于指定表名;@TableId
用于指定主键字段及生成策略,支持AUTO
(数据库自增)、ASSIGN_ID
(雪花算法生成)等策略;@TableField
用于处理字段名不一致、与数据库关键字冲突等情况,还可通过exist = false
标识非数据库字段。
强大的条件构造器:告别硬编码 SQL
MyBatis-Plus 的条件构造器是其核心亮点之一,能满足各种复杂查询需求:
QueryWrapper
和LambdaQueryWrapper
用于构建查询、删除、更新的WHERE
条件。其中,LambdaQueryWrapper
借助 Java 8 的 Lambda 表达式引用实体类属性,具备类型安全和防拼写错误的优势,如wrapper.like(User::getUsername, "o").ge(User::getBalance, 1000)
;UpdateWrapper
和LambdaUpdateWrapper
用于处理特殊的更新场景,例如批量更新时可通过setSql("balance = balance - 200")
实现余额扣除操作。
使用LambdaQueryWrapper的例子:
java
LambdaQueryWrapper<User> lambdaWrapper = new LambdaQueryWrapper<>();
lambdaWrapper
.eq(User::getName, "张三")
.ge(User::getAge, 18)
.like(User::getEmail, "@gmail")
.orderByDesc(User::getCreateTime);
List<User> userList = userMapper.selectList(lambdaWrapper);
使用 QueryWrapper的例子:
java
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper
.eq("name", "张三") // 等于条件
.ge("age", 18) // 大于等于条件
.like("email", "@gmail") // 模糊查询
.orderByDesc("create_time"); // 降序排序
List<User> userList = userMapper.selectList(queryWrapper);
配置与扩展:灵活适配项目需求
我个人理解,和mybatis 相差不大。
MyBatis-Plus 的配置继承了 MyBatis 原生配置并增加了自定义项,可在application.yml
中进行配置,如设置别名扫描包、Mapper.xml 路径、开启下划线与驼峰映射等。其global-config
还能配置全局的 ID 生成策略、更新策略等,例如将id-type
设为assign_id
使用雪花算法生成 ID。
MyBatis-Plus 通过无侵入的设计和丰富的特性,让开发者既能享受 MyBatis 的灵活性,又能借助自动封装的 CRUD 操作和条件构造器提升开发效率,是 Java 开发中处理数据库操作的得力助手。