Mybatis Plus exists 用法(超详细)
一则或许对你有用的小广告
欢迎加入小哈的星球,你将获得:专属的实战项目(4个项目都能学) / 1v1 提问 / 简历修改 / Java 学习路线 / 社群讨论 / 学习打卡 / 每月赠书
《Spring AI 项目实战(问答机器人、RAG 智能客服、联网搜索)》已完结,基于
Spring AI + Spring Boot 3.x + JDK 21...,查看介绍《从零手撸:仿小红书(微服务架构)》 已完结,基于
Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...,查看介绍;演示链接:http://116.62.199.48:7070/《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接:http://116.62.199.48/
新开坑项目:《从零手撸:秒杀系统高并发优化实战》 正在更新中...,查看介绍
截止目前,星球内专栏累计输出 150w+ 字,讲解图 5110+ 张,还在持续爆肝中.. 后续还会上新更多项目,已有 4700+ 小伙伴加入学习,欢迎点击围观
前言
大家好,我是小哈。
本小节中讲解如何通过 Mybatis Plus 中的 Wrapper 组装 SQL 从而实现 exists 语句。
方法
Wrapper 条件构造器中 exists 相关的方法如下:
exists(String existsSql)
exists(boolean condition, String existsSql)
参数说明:
condition: 是否组装条件;
代码示例
exists 方法是父类 AbstractWrapper (抽象类)中定义的方法,子类 QueryWrapper、LambdaQueryWrapper、UpdateWrapper、LambdaUpdateWrapper 均可调用,以下使用 QueryWrapper 以及 Lambda 形式来演示:
// 组装查询条件
QueryWrapper<User> wrapper = new QueryWrapper<>();
wrapper.exists("select id from user where age = 20");
// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (EXISTS (select id from user where age = 20))
List<User> users = userMapper.selectList(wrapper);
Lambda 形式:
// 实际执行 SQL : SELECT id,name,age,gender FROM user WHERE (EXISTS (select id from user where age = 20))
List<User> users1 = userMapper.selectList(new QueryWrapper<User>()
.lambda().exists("select id from user where age = 20"));
