Mybatis Plus not exists 用法(超详细)

更新时间 2022-12-30 12:32:33

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

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

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

Mybatis Plus Wrapper 条件构造器

前言

大家好,我是小哈。

本小节中讲解如何通过 Mybatis Plus 中的 Wrapper 组装 SQL 从而实现 not exists 语句。

方法

Wrapper 条件构造器中 not exists 相关的方法如下:

notExists(String notExistsSql)
notExists(boolean condition, String notExistsSql)

参数说明:

  • condition : 是否组装条件;

代码示例

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

// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.notExists("select id from user where age = 20");

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

Lambda 形式:

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

Mybatis Plus Wrapper 条件构造器