现在的位置: 首页 > 综合 > 正文

Mysql 和Oracle中 exists的用法总结

2014年02月07日 ⁄ 综合 ⁄ 共 628字 ⁄ 字号 评论关闭
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 NULLORDER BY CategoryName
ASC/DESC]

比较使用
EXISTS 和 IN 的查询,如下例子比较了两个语义类似的查询。第一个查询使用 EXISTS 而第二个查询使用 IN。注意两个查询返回相同的信息

SELECT 

distinct 

抱歉!评论已关闭.