这些Mybatis-Plus的使用小技巧,你应该知道的

推荐学习

  • 真香警告!Alibaba珍藏版mybatis手写文档 , 刷起来
  • 重识SSM , “超高频面试点+源码解析+实战PDF” , 一次性干掉全拿走
最近在用 Mybatis-Plus , 嗯 , 真香!!!今天就来说说 Mybatis-Plus 的那些使用技巧
这些Mybatis-Plus的使用小技巧,你应该知道的文章插图
1、条件查询(QueryWrapper)如果说 , 我们需要查询的 SQL 语句如下:
SELECT * FROM user_info WHERE age = 20那么对应的代码可以为:
QueryWrapper queryWrapper = new QueryWrapper<>();queryWrapper.eq("age", 20);List list = userInfoMapper.selectList(queryWrapper );以上就是查询用户表 , 用户年龄等于20的用户信息
2、条件查询(QueryWrapper lambda)QueryWrapper queryWrapper = new QueryWrapper<>();queryWrapper.lambda().eq(UserInfo::getAge, 20);List list = userInfoMapper.selectList(queryWrapper );以上就是 QueryWrapper 的 lambda 表达式写法 , 这样能够避免写字段名写错 , 或者未转换驼峰写法导致 SQL 错误
3、条件查询(LambdaQueryWrapper)LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(UserInfo::getAge, 20);List list = userInfoMapper.selectList(queryWrapper );LambdaQueryWrapper 与 QueryWrapper 的 lambda 写法基本一致
4、分页查询// 条件查询LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(UserInfo::getAge, 20);// 分页对象Page queryPage = new Page<>(page, limit);// 分页查询IPage iPage = userInfoMapper.selectPage(queryPage , queryWrapper);// 数据总数Long total = iPage.getTotal();// 集合数据List list = iPage.getRecords();以上就是分页查询 , 如果无需条件查询 , queryWrapper 可为 null
5、分页查询(联表)当我们需要关联表格分页查询时 , 第3步已经满足不了我们的需求了 , 那么我们需要进行联表分页查询
假设我们需要的 SQL 语句如下:
SELECT a.*, b.`name` AS sex_text FROM user_info a LEFT JOIN user_sex b ON ( a.sex = b.id ) WHERE 1 = 1AND a.age > 20那么我们需要进行如下操作:
  • 1、新建 UserInfoVO.java
import com.zyxx.entity.UserInfo;import lombok.Data;@Datapublic class UserInfoVO extends UserInfo {// 性别private String sexText;
  • 2、UserInfoMapper.java 中
IPage list(Page page, @Param(Constants.WRAPPER) Wrapper queryWrapper);
  • 3、UserInfoMapper.xml 中
SELECTa.*,b.`name` AS sex_textFROMuser_info aLEFT JOIN user_sex b ON ( a.sex = b.id )${ew.customSqlSegment}
  • 4、UserInfoServiceImpl.java 中
// 条件查询LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(UserInfo::getAge, 20);// 分页对象Page queryPage = new Page<>(page, limit);// 分页查询IPage iPage = userInfoMapper.list(queryPage , queryWrapper);// 数据总数Long total = iPage.getTotal();// 用户数据List list = iPage.getRecords();以上就是分页查询(联表)时的操作 , 这个应该是用的比较多的
6、AND 和 ORqueryWrapper 默认是按照 and 来连接的 , 但是在我们业务需求中 , 肯定会用到 or 来写 SQL
  • 1、初级假设我们需要的 SQL 语句如下:
SELECT a.* FROM user_info a WHERE 1 = 1AND a.id <> 1AND ( a.`name` = 'jack' OR a.phone = '13888888888' )那么我们可以这样写:
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();// AND a.id <> 1 queryWrapper.ne(UserInfo::getId, "1");// AND ( a.`name` = 'jack' OR a.phone = '13888888888' )queryWrapper.and(i -> i.eq(UserInfo::getName, "jack").or().eq(UserInfo::getPhone, "13888888888"));// 查询结果List list = userInfoMapper.selectList(queryWrapper);以上就完成了初级的 and 和 or 联用的情况
  • 2、复杂假设我们需要的 SQL 语句如下:
SELECT a.* FROM user_info a WHERE 1 = 1AND a.id <> 1AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )那么我们可以这样写:
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();// AND a.id <> 1 queryWrapper.ne(UserInfo::getId, "1");// AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )queryWrapper.and(i -> (i.and(j -> j.eq(UserInfo::getName, "jack").eq(UserInfo::getCategory, 1))).or(j -> j.eq(UserInfo::getPhone, "13888888888").eq(UserInfo::getCategory, 2)));// 查询结果List list = userInfoMapper.selectList(queryWrapper);以上就完成了复杂的 and 和 or 联用的情况
那么以后遇见更复杂的 , 可以按此规则继续进行拼接 SQL