首页 热点资讯 义务教育 高等教育 出国留学 考研考公
您的当前位置:首页正文

MySQL中关于exists和notexists的示例分享

2020-11-09 来源:华佗小知识

这篇文章主要介绍了mysql exists与not exists实例详解的相关资料,鉴于 not exists 的效率往往要高于 not in , 所以一般情况下会使用前者替代后者,需要的朋友可以参考下

mysql exists与not exists实例详解

tableA

|column1 | column1 |column3 |

tableb

|column1 | column1 |column3 |

要查询 tableA 的数据,条件是是 tableA.column1 不在 tableB 的 tableB.column2 中

也就是要得到类似以下语句的效果(not in 效果不完全等同于 not exists , 如果子查询中出现空记录, 则整个查询语句不会返回数据)


SELECT 
 a.*
FROM
 tableA a
WHERE 
 a.column1 not in (
 SELECT column2 FROM tableB
 )

可以使用如下语句来实现


SELECT
 a.*
FROM
 tableA a
WHERE
 NOT EXISTS(
 SELECT b.column2 FROM tableB b WHERE a.colunm1=b.column2
 )

以上只是两张表的情况, 其实在多张表的连接查询中也是比较好用的. 以上写法同样适用于exists

显示全文