Mysql Exists 和Not Exists用法

这里着重介绍Not Exists(Exists用法类似),Not Exists 不存在

  • 用法:
    Select * from TableA a where Not Exists (Select * from TableB b where a.id=b.id and a.name=b.name);
  1. Not Exists 用在where之后,且后面紧跟子查询语句(带括号);
  2. Not Exists(Exists) 并不关心子查询的结果具体是什么,只关心子查询有没有结果;
  3. 这条语句的意思,把TableA的记录逐条代入到子查询,如果子查询结果集为空,说明不存在,那么这条TableA的记录出现在最终结果集,否则被排除;
  • 用法:
    Select * from TableA a where Not Exists (Select 1 from TableB);

这条语句子查询无论什么情况下都不为空,导致最终的结果集为空,因为TableA中每条记录对应的子查询都有结果集,表示都存在,所以最终结果集为空;

你可能感兴趣的:(Mysql Exists 和Not Exists用法)