EXISTS 子查询语法:
SELECT … FROM 表名 WHERE EXISTS(子查询);
该语法可以理解为:将主查询的数据,放到子查询中做条件验证,根据验证结果(TRUE 或 FALSE)来决定主查询的数据结果是否得以保留。
NOT EXISTS 子查询语法:
EXISTS和IN一样,同样允许添加NOT关键字实现取反操作,NOT EXISTS表示不存在。
SELECT … FROM 表名 WHERE NOT EXISTS(子查询);
原理解释
EXISTS (sql 返回结果集为真)
NOT EXISTS(sql 不返回结果集为真(或返回结果集为假)
拆解过程
exists与not exists案例解析
SELECT A.*
FROM A
WHERE
EXISTS (SELECT B.* FROM B WHEN A.id = B.id)
首先mysql底层先执行
SELECT A.* FROM A
然后将其结果集作为条件,在where中进行筛选,exists筛选结果集为true的数据项,而not exists相反,返回结果集为false的数据项
总结:
-
EXISTS (subquery) 只返回 TRUE 或 FALSE,因此子查询中的 SELECT * 也可以是 SELECT 或其他,官方说法是实际执行时会忽略 SELECT 清单,因此没有区别。
-
EXISTS 子查询的实际执行过程可能经过了优化而不是我们理解上的逐条对比,如果担忧效率问题,可进行实际检验以确定是否有效率问题。
-
EXISTS 子查询往往也可以用条件表达式、其他子查询或者 JOIN 来替代,何种最优需要具体问题具体分析。