SQL查询高级特性解析
1. EXISTS 运算符
EXISTS 运算符常与相关子查询结合使用。以下是一个示例,查询所有没有注册记录的课程安排:
select o.*
from offerings o
where not exists
(select r.*
from registrations r
where r.course = o.course
and r.begindate = o.begindate);
结果如下:
| COURSE | BEGINDATE | TRAINER | LOCATION |
| ------ | ---------- | ------- | -------- |
| ERM | 15 - JAN - 2001 | | |
| PRO | 19 - FEB - 2001 | | DALLAS |
| RSD | 24 - FEB - 2001 | 7788 | CHICAGO |
| XML | 18 - SEP - 2000 | | BOSTON |
EXISTS 运算符不关心子查询返回的实际行和列值,只检查子查询结果是否存在。若子查询至少返回一行,EXISTS 运算符返回 TRUE;若不返回任何行,则返回 FALSE。
跟在 EXISTS 运算符后的子查询通常是相关子查询。若为非相关子查询,对于主查询的每一行,其结果都相同,EXISTS 运算符会变成“全有或全无”的运算符。
超级会员免费看
订阅专栏 解锁全文
1209

被折叠的 条评论
为什么被折叠?



