通过IService中提供的Lambda方法,简化复杂/动态sql语句的编写

案例:

要求实现一个根据复杂条件查询用户的接口,查询条件如下:

  1. name:用户名关键字,可以为空

  2. status:用户状态,可以为空

  3. minBalance:最小余额,可以为空

  4. maxBalance:最大余额,可以为空

可以理解成一个用户的后台管理界面,管理员可以自己选择条件来筛选用户,因此上述条件不一定存在,需要做判断。

如果用mybatis编写,我们可以通过xml映射实现动态sql语句,如下图所示,但是这样比较麻烦。

我们可以先构建条件构造器,再通过IService中的list方法进行查询。代码如下:

java 复制代码
@GetMapping("/list")
@ApiOperation("根据id集合查询用户")
public List<UserVO> queryUsers(UserQuery query){
    // 1.组织条件
    String username = query.getName();
    Integer status = query.getStatus();
    Integer minBalance = query.getMinBalance();
    Integer maxBalance = query.getMaxBalance();
    LambdaQueryWrapper<User> wrapper = new QueryWrapper<User>().lambda()
            .like(username != null, User::getUsername, username)
            .eq(status != null, User::getStatus, status)
            .ge(minBalance != null, User::getBalance, minBalance)
            .le(maxBalance != null, User::getBalance, maxBalance);
    // 2.查询用户
    List<User> users = userService.list(wrapper);
    // 3.处理vo
    return BeanUtil.copyToList(users, UserVO.class);
}

但是这样还是比较复杂,我们甚至可以不用构建条件构造器,直接调用lambdaQuery方法即可,代码如下:

java 复制代码
@GetMapping("/list")
@ApiOperation("根据id集合查询用户")
public List<UserVO> queryUsers(UserQuery query){
    // 1.组织条件
    String username = query.getName();
    Integer status = query.getStatus();
    Integer minBalance = query.getMinBalance();
    Integer maxBalance = query.getMaxBalance();
    // 2.查询用户
    List<User> users = userService.lambdaQuery()
            .like(username != null, User::getUsername, username)
            .eq(status != null, User::getStatus, status)
            .ge(minBalance != null, User::getBalance, minBalance)
            .le(maxBalance != null, User::getBalance, maxBalance)
            .list();
    // 3.处理vo
    return BeanUtil.copyToList(users, UserVO.class);
}

需要注意的是lambdaQuery方法中除了可以构建条件,还需要在链式编程的最后添加一个list(),这是在告诉MP我们的调用结果需要是一个list集合。这里不仅可以用list(),可选的方法有:

.one():最多1个结果
.list():返回集合结果
.count():返回计数结果

MybatisPlus会根据链式编程的最后一个方法来判断最终的返回结果。

相关推荐
MY_TEUCK3 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
今天长肉了吗4 小时前
银行风控项目踩坑实录:指标跑了6小时,风险评分全挂了
java
随读手机4 小时前
多式联运信息交互平台完整方案(2026版)
java·ai·eclipse·云计算·区块链
阿波罗尼亚4 小时前
数据库序列(Sequence)
数据库
Junsir大斗师5 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish5 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午5 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
nj01285 小时前
Spring 循环依赖详解:三级缓存、早期引用、AOP 代理与懒加载
java·spring·缓存
野生技术架构师5 小时前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试
一只叫煤球的猫6 小时前
ThreadForge 源码解读一:ThreadScope 如何把并发任务放进清晰边界?
java·面试·开源