1. 快速上手
1.1 准备工作


1.2 编码
创建实体类 UserInfo

编写Mapper接口类

MyBatisPlus提供了一个基础的BaseMapper接口,已经实现了单标的CRUD,我们自定义的Mapper只需要继承这个BaseMapper,无需自己实现单表CRUD

1.3 CRUD测试

2. Mybatis-Plus 复杂操作
2.1 常见注解
Mybatis是如何知道要操作那张表,表中的哪些字段

UserInfoMapper 在继承 BaseMapper 时指定了一个泛型,这个UserInfo就是与数据表相对应的实体类
Mybatis-Plus 会根据这个实体类来推断表的信息
默认情况如下:
-
表名
-
字段
-
主键:默认是id
2.1.1 @TableName

可以通过@TableName来表示实体类对应的表

2.1.2 @TableField


2.1.3 @Tabled


2.2 条件构造器
入门程序里的使用,都是简单的CRUD,在实际的应用场景中,我们还需要使用更复杂的操作,Mybatis-Plus 也提供了相应的支持
Mybatis-Plus 提供了一套强大的条件构造器(Wrapper)用于构建复杂的查询条件条件构造器 | MyBatis-Plus
2.2.1 QueryWrapper
QueryWrapper并不只是用于查询语句,无论是修改、删除、查询都可以使用QueryWrapper来构建查询条件
查询
SELECT id,username,password,age FROM user_info WHERE age = 18 AND username
like "%min%"


更新
UPDATE user_info SET delete_flag=? WHERE age < 20




删除
DELETE FROM user_info WHERE age = 4


2.2.2 UpdateWrapper
对于更新,我们可以直接使用 UpdateWrapper ,在不创建实体对象的情况下,直接设置更新字段和条件
UPDATE user_info SET delete_flag=0, age=5 WHERE id IN (1,2,3)




2.2.3 LamdbaQueryWrapper
QueryWrapper 和 UpdateWrapper 都存在一个问题,就是需要写死字段名,如果字段名发生变更,可能会因为测试不到位造成错误
Mybatis-Plus 提供了一种基于Lambda表达式的条件和构造器,它通过Lambda 表达式引用实体类属性,从而避免了硬编码字段名,也提高了代码的可读性和可维护性


2.2.4 LambdaUpdateWrapper


2.3 自定义SQL
在实际开发中,Mybatis-Plus提供的操作不能满足实际需求,Mybatis-Plus 也提供了自定义SQL功能,我们可以利用Wrapper构造查询条件,再结合Mapper编写SQL


