通过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会根据链式编程的最后一个方法来判断最终的返回结果。

相关推荐
想不明白的过度思考者4 分钟前
SpringAOP:Java 三大代理模式:从静态代理到 JDK & CGLIB 动态代理
java·开发语言·代理模式
yaoyouzhong5 分钟前
MySQL中DROP、TRUNCATE和DELETE
java
TDengine (老段)5 分钟前
TDengine IDMP 可视化 ——柱状图
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
Meepo_haha6 分钟前
Spring boot 3.3.1 官方文档 中文
java·数据库·spring boot
__土块__8 分钟前
一次 Spring 循环依赖源码走读:从三级缓存误用到 Bean 生命周期深度解析
java·spring·源码分析·aop·bean生命周期·循环依赖·三级缓存
妙蛙种子3118 分钟前
【Java设计模式 | 创建者模式】单例模式
java·开发语言·后端·单例模式·设计模式
xcLeigh10 分钟前
KES数据库数据类型与SQL高级语法
大数据·数据库·sql·kes·高级语法·数据选型
种时光的人10 分钟前
Spring AI 工具调用(ToolCalling)完整使用教程
java·人工智能·后端·spring·ai·java开发·spring ai
立莹Sir2 小时前
Spring Bean 生命周期详解
java·python·spring
uElY ITER2 小时前
Spring全家桶简介
java·后端·spring