select c.customerId,companyName
From Customers c
where exists(select orderID from Orders o where o.customerID=c.custormerID)
这里面的EXISTS是如何运作呢?子查询返回的是OrderId字段,可是外面的查询要找的是CustomerID和CompanyName字段,这两个字段肯定不在OrderID里面啊,这是如何匹配的呢?
EXISTS用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值True或False。
EXISTS 指定一个子查询,检测行的存在。语法:EXISTS subquery。参数 subquery 是一个受限的 SELECT 语句 (不允许有 COMPUTE 子句和 INTO 关键字)。结果类型为 Boolean,如果子查询包含行,则返回
TRUE。
在子查询中使用
NULL 仍然返回结果集,如下例子在子查询中指定 NULL,并返回结果集,通过使用 EXISTS 仍取值为 TRUE:
SELECT
CategoryName
FROM
Categories
WHERE
EXISTS
(SELECT
NULL
)
ORDER
BY
CategoryName
[ASC/DESC]
比较使用
EXISTS 和 IN 的查询,如下例子比较了两个语义类似的查询。第一个查询使用 EXISTS 而第二个查询使用 IN。注意两个查询返回相同的信息
SELECT
distinct