SQL循序渐进(23)UNION 和 外部连接
来源:互联网 发布:centos服务器安全设置 编辑:程序博客网 时间:2024/05/29 19:14
有些时候,你可以想一起看多个查询的结果、组合它们的输出,你可以使用UNION关键字。为了合并以下两个查询的输出:显示所有买方的ID和已经有定货的顾客,你可以使用以下语句:
SELECT BUYERID
FROM ANTIQUEOWNERS
SELECT OWNERID
FROM ORDERS;
这里要注意SQL要求SELECT的列表必须匹配,即列于数据类型匹配。在本例子中,BuyerID 和OwnerID都是相同的数据类型,同为Interger(整型)。同时还有一提的是,SQL但使用UNION的使用会进行自动复制排除。而在单一的查询中,你就必须使用DISTINCT。
Outer Join(外部连接)通常是在JOIN查询被联合,而行没有包括到JOIN中的时候使用,特别是在常量文本"flags"被包括的时候尤为有用。下面我们看看这个查询先:
SELECT OWNERID, 'is in both Orders & Antiques'
FROM ORDERS, ANTIQUES
WHERE OWNERID = BUYERID
SELECT BUYERID, 'is in Antiques only'
FROM ANTIQUES
WHERE BUYERID NOT IN
(SELECT OWNERID
FROM ORDERS);
第一个查询做了一个连接以列出两个表中的每个owener,并且在ID后面放置一个标记线来重复引用。这个UNION合并了这个列表以及以下第二个的列表。第二个列表是列出不是在Orders 表的ID,这样就产生了在JOIN查询之外的ID列表,它是利用引用标签列出的。这可能是一种最容易的方法来产生这个列表。
这个概念对于主键跟外码有关的状况是很有用的,但是有些主键的外码值是NULL。比如,在一个表中,主键是salesperson,而在其它的表中主键是customers,并且它们的salesperson列在相同的行。然而,如果salesperson没有customers的时候,这个人的名字就不会出现在customer表中。如果所有salespersons的列表要显示出来,那么就要外部连接了。<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- SQL循序渐进(23)UNION 和 外部连接
- SQL 连接语句(union和join)
- SQL UNION 和 UNION ALL
- SQL UNION 和 UNION ALL
- SQL UNION ALL和UNION
- sql union和union all
- SQL Union和Union all
- SQL UNION 和 UNION ALL
- SQL UNION 和 UNION ALL
- SQL UNION 和 UNION ALL
- SQL UNION 和 UNION ALL
- SQL:union 和 union all
- SQL Union和SQL Union All用法
- SQL Union和SQL Union All用法
- SQL Union和SQL Union All用法
- SQL Union和SQL Union All用法
- SQL Union和SQL Union All用法
- SQL Union和SQL Union All用法
- Main
- 企业用人与工作经验
- 排序
- 使用内存共享机制进程间通讯
- c# 线程同步:详解lock,monitor,同步事件和等待句柄以及mutex
- SQL循序渐进(23)UNION 和 外部连接
- 编写和建立存储过程,并定义合适的过程返回状态码和信息
- 情尽桥
- 又一次生日
- SQL循序渐进(24)嵌入SQL
- 如何从深层递归中跳出?
- SQL循序渐进(22)EXISTS 和 ALL
- Spring的事务,经典配置
- VML Chart 控件