SQL循序渐进(23)UNION 和 外部连接

UNION 和 外部连接

有些时候,你可以想一起看多个查询的结果、组合它们的输出,你可以使用UNION关键字。为了合并以下两个查询的输出:显示所有买方的ID和已经有定货的顾客,你可以使用以下语句:

Select BUYERID

FROM ANTIQUEOWNERS

UNION

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

UNION

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的列表要显示出来,那么就要外部连接了。

收藏&分享:
  • Print
  • Digg
  • Sphinn
  • del.icio.us
  • Facebook
  • Google Bookmarks
  • email
  • Haohao
  • MisterWong
  • PDF
  • Ping.fm
  • QQ书签
  • RSS
  • StumbleUpon
  • Twitter
  • 豆瓣
  • 豆瓣九点

Burn after reading » Now you're done reading. What's next?

砼砼

小时候,一直以为自己的咪咪是蚊子叮的,每天洗完澡以后就拿着盒万金油在搽,希望它可以早日康复,直到念大班的时候偶放弃类

随机推荐

日志信息

如需转载烦请添加以下信息: 本文内容转载自砼砼's blog[http://TossP.com].
如喜欢这篇文章或者本站,建议您RSS订阅本站,以及时地获取更多精彩内容!

可以通过订阅Comments RSS 2.0 feed,一直不断的跟踪这篇日志的的评论~
欢迎您点击发表评论参与这篇日志的讨论,如果您需要引用或者转载此文,请确保让我知道,并建议使用trackback将转载信息通知到本页面。

Leave a Reply