sql exists 和 not exists解读

在 SQL 中,EXISTSNOT EXISTS 是用于检查子查询是否返回任何行的条件语句。这两个关键字常用于与子查询结合,以基于子查询的结果来过滤主查询的结果。

EXISTS

EXISTS 子查询用于检查子查询是否返回至少一行。如果子查询返回至少一行,那么 EXISTS 条件为真,否则为假。

示例:

假设我们有两个表,一个是 students(学生表),另一个是 courses(课程表)。我们想要找出至少注册了一门课程的学生。

复制代码

sql复制代码

|---|--------------------------------------|
| | SELECT student_name |
| | FROM students s |
| | WHERE EXISTS ( |
| | SELECT 1 |
| | FROM courses c |
| | WHERE c.student_id = s.student_id |
| | ); |

在这个例子中,对于 students 表中的每一行(即每一个学生),子查询都会检查 courses 表中是否存在与当前学生相关的行。如果存在,那么 EXISTS 条件为真,该学生的名字就会被选出来。

NOT EXISTS

NOT EXISTSEXISTS 相反,它用于检查子查询是否没有返回任何行。如果子查询没有返回任何行,那么 NOT EXISTS 条件为真,否则为假。

示例:

假设我们想要找出没有注册任何课程的学生。

复制代码

sql复制代码

|---|--------------------------------------|
| | SELECT student_name |
| | FROM students s |
| | WHERE NOT EXISTS ( |
| | SELECT 1 |
| | FROM courses c |
| | WHERE c.student_id = s.student_id |
| | ); |

在这个例子中,对于 students 表中的每一行(即每一个学生),子查询都会检查 courses 表中是否存在与当前学生相关的行。如果不存在,那么 NOT EXISTS 条件为真,该学生的名字就会被选出来。

注意事项

  • EXISTSNOT EXISTS 的子查询中,通常不需要选择特定的列,因为只关心子查询是否返回了行。因此,经常会在子查询中选择一个常量(如 SELECT 1)来简化查询。
  • 这两个关键字可以与任何有效的 SQL 子查询结合使用,而不仅仅是与 SELECT 语句结合。例如,它们也可以与 UPDATEDELETE 或其他 SQL 语句结合使用。
  • 由于 EXISTSNOT EXISTS 只关心子查询是否返回了行,而不关心返回了多少行或返回了哪些行,因此它们通常比使用 COUNT() 或其他聚合函数与子查询结合使用更加高效。
相关推荐
胖头鱼的鱼缸(尹海文)3 分钟前
数据库管理-第386期 使用OCP部署OceanBase 4.4.1社区版集群(20251107)
数据库·oceanbase
Craaaayon5 分钟前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
一 乐14 分钟前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
WarriorTan24 分钟前
理解PostgreSQL中的数据块
数据库·postgresql
学好statistics和DS30 分钟前
三个好思路:SQL并行化处理、混淆矩阵和特征交叉
数据库·sql·矩阵
唐僧洗头爱飘柔95271 小时前
【GORM(3)】Go的跨时代ORM框架!—— 数据库连接、配置参数;本文从0开始教会如何配置GORM的数据库
开发语言·数据库·后端·golang·gorm·orm框架·dsn
谅望者1 小时前
在 macOS 上使用 Homebrew 安装 MySQL 8.0 完整指南
数据库·sql·mysql
程序员卷卷狗2 小时前
MySQL 页结构与数据存储原理全解析》
数据库·mysql
hweiyu002 小时前
MySQL 从入门到精通(视频教程)
数据库·mysql
小跌—2 小时前
MySQL:数据库基础
数据库·mysql