22、SQL查询高级特性解析

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 运算符会变成“全有或全无”的运算符。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值