Mybatis Plus Condition 详解(结合代码示例)

更新时间 2023-01-12 16:05:36

一则或许对你有用的小广告

欢迎加入小哈的星球 ,你将获得:专属的项目实战 / Java 学习路线 / 一对一提问 / 学习打卡 / 赠书活动

目前, 星球 内第一个项目:全栈前后端分离博客项目,演示地址:http://116.62.199.48/, 1.0 版本已经更新完毕,正在更新 2.0 版本。采用技术栈 Spring Boot + Mybatis Plus + Vue 3.x + Vite 4手把手,前端 + 后端全栈开发,从 0 到 1 讲解每个功能点开发步骤,1v1 答疑,陪伴式直到项目上线,目前已更新了 224 小节,累计 35w+ 字,讲解图:1544 张,还在持续爆肝中,后续还会上新更多项目,目标是将 Java 领域典型的项目都整上,如秒杀系统、在线商城、IM 即时通讯、权限管理等等,已有 1000+ 小伙伴加入,欢迎点击围观

前言

大家好,我是小哈。

前面小节中,我们已经学习了 Mybatis Plus 中使用频率超高的条件构造器 ,细心的小伙伴应该注意到,很多条件判断方法都提供了一个带有 boolean 类型 condition 参数的重载方法,如下面的截图,这玩意到底是干嘛用的呢?

本文我们就结合具体示例详细讲一讲。

Wrapper 中的 condition

布尔类型的 condition 顾名思义就是条件判断。举个栗子,实际项目中,如果是一个查询分页数据的页面,用户通常可以手动选择多个条件进行查询,那么后台的代码实现上,Wrapper 条件就是动态组装的,需要对每一个可能会出现的条件进行判断,伪代码大致如下:

if (字段1 != null) {
  wrapper.eq("name", "犬小哈")
}

if (字段2 != null) {
  wrapper.ge("age", 20)
}

// ...省略

如何 if 判断只有几个还好,一旦给你来 10 个,你就会发现代码又臭又长,于是救世主 condition 出现了,它可以帮助我们省略冗长的 if 代码,让动态组装的判断更加优雅。

举个示例,假设分页接口中,前端可能传过来的动态条件字段为姓名,年龄(范围类型),那么可以通过 condition 可以如下实现:

@Test
void testCondition() {
    // 模拟前端传过来的数据
    String name = "犬小哈";
    // 年龄大于等于 20 且小于等于 30 的用户
    Integer ageStart = 20;
    Integer ageEnd = 30;

    QueryWrapper<User> wrapper = new QueryWrapper<>();
    wrapper.eq(StringUtils.isNotBlank(name), "name", name)
    .ge(ageStart != null, "age", ageStart)
    .le(ageEnd != null, "name", ageEnd);

    List<User> users = userMapper.selectList(wrapper);
}

Lambda 形式如下:

TIP : 推荐使用 Lambda 形式,可以不用手动填写字段名。

@Test
void testCondition() {
    // 模拟前端传过来的数据
    String name = "犬小哈";
    // 年龄大于等于 20 且小于等于 30 的用户
    Integer ageStart = 20;
    Integer ageEnd = 30;

    LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();
    wrapper.eq(StringUtils.isNotBlank(name), User::getName, name)
    .ge(ageStart != null, User::getAge, ageStart)
    .le(ageEnd != null, User::getAge, ageEnd);

    List<User> users = userMapper.selectList(wrapper);
    users.forEach(System.out::println);
}

执行单元测试,实际执行 SQL 如下:

功能正常,相比较上面需要写一堆 if 判断,我们可以直接将判断条件传给 condition 参数,代码看上去舒服多了,有木有~

结语

本小节中,我们结合代码示例,详细讲解了 Mybatis Plus 中的条件构造器 Wrapper 方法中的 condition 是什么,以及如何使用,希望小伙伴在实际项目开发中,也要善用它,让代码看起来更加优雅。