Mybatis Plus notInSql 子查询用法(超详细)

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

欢迎加入小哈的星球 ,你将获得:专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...点击查看项目介绍
  • 《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接: http://116.62.199.48/

截止目前, 星球 内专栏累计输出 66w+ 字,讲解图 2896+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,权限管理,Spring Cloud Alibaba 微服务等等,已有 2300+ 小伙伴加入学习 ,欢迎点击围观

Mybatis Plus Wrapper 条件构造器

前言

大家好,我是小哈。

本小节中给大家讲解如何通过 Mybatis Plus 中的 Wrapper 组装 SQL 实现 not in 子查询语句。

方法

Wrapper 条件构造器中 not in 子查询相关的方法如下:

notInSql(R column, String inValue)
notInSql(boolean condition, R column, String inValue)

代码示例

notInSql 方法是父类 AbstractWrapper (抽象类)中定义的方法,子类 QueryWrapperLambdaQueryWrapperUpdateWrapperLambdaUpdateWrapper 均可调用,以下用 QueryWrapper 来演示:

// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
// 子查询 not in
wrapper.notInSql("id", "1,2,3,4");

// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (id NOT IN (1,2,3,4))
List<User> users = userMapper.selectList(wrapper);
// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
// 子查询 not in
wrapper.notInSql("id", "select id from user where id > 10");

// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (id NOT IN (select id from user where id > 10))
List<User> users = userMapper.selectList(wrapper);

Lambda 形式:

// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (id NOT IN (select id from user where id > 10))
List<User> users1 = userMapper.selectList(new QueryWrapper<User>()
                .lambda().notInSql(User::getId, "select id from user where id > 10"));

Mybatis Plus Wrapper 条件构造器