外联接。

外联接能够是左向外联接、右向外联接或完整外部联接。 

在 FROM 子句中指定外联接时,能够由下列几组keyword中的一组指定:



LEFT JOIN 或 LEFT OUTER JOIN。

左向外联接的结果集包含 LEFT OUTER 子句中指定的匹配条件的行左表的全部行



RIGHT JOIN 或 RIGHT OUTER JOIN。

右向外联接是左向外联接的反向联接。将返回匹配条件的行右表的全部行



FULL JOIN 或 FULL OUTER JOIN。 

完整外部联接返回左表和右表中的全部行。当某行在还有一个表中没有匹配行时。则还有一个表的选择列表列包括空值。

假设表之间有匹配行,则整个结果集行包括基表的数据值。



内联接 仅 当至少有一个同属于两表的行符合联接条件时,内联接才返回行。

内联接消除与还有一个表中的不论什么行不匹配的行而外联接会返回 FROM 子句中提到的至少一个表或视图的全部行,仅仅要这些行符合不论什么 WHERE 或 HAVING 搜索条件。将检索通过左向外联接引用的左表的全部行,以及通过右向外联接引用的右表的全部行。完整外部联接中两个表的全部行都将返回。



Microsoft® SQL Server™ 2000 对在 FROM 子句中指定的外联接使用下面 SQL-92 keyword: 



LEFT OUTER JOIN 或 LEFT JOIN





RIGHT OUTER JOIN 或 RIGHT JOIN





FULL OUTER JOIN 或 FULL JOIN 

SQL Server 支持 SQL-92 外联接语法,以及在 WHERE 子句中使用 *= 和 =* 运算符指定外联接的旧式语法。因为 SQL-92 语法不easy产生歧义。而旧式 Transact-SQL 外联接有时会产生歧义。因此建议使用 SQL-92 语法。



使用左向外联接

如果在 city 列上联接 authors 表和 publishers 表。结果仅仅显示在出版商所在城市居住的作者(本例中为 Abraham Bennet 和 Cheryl Carson)。



若要在结果中包含全部的作者。而无论出版商是否住在同一个城市。请使用 SQL-92 左向外联接。以下是 Transact-SQL 左向外联接的查询和结果:



USE pubs

SELECT a.au_fname, a.au_lname, p.pub_name

FROM authors a LEFT OUTER JOIN publishers p

   ON a.city = p.city

ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC



以下是结果集:



au_fname             au_lname                       pub_name          

-------------------- ------------------------------ ----------------- 

Reginald             Blotchet-Halls                 NULL

Michel               DeFrance                       NULL

Innes                del Castillo                   NULL

Ann                  Dull                           NULL

Marjorie             Green                          NULL

Morningstar          Greene                         NULL

Burt                 Gringlesby                     NULL

Sheryl               Hunter                         NULL

Livia                Karsen                         NULL

Charlene             Locksley                       NULL

Stearns              MacFeather                     NULL

Heather              McBadden                       NULL

Michael              O'Leary                        NULL

Sylvia               Panteley                       NULL

Albert               Ringer                         NULL

Anne                 Ringer                         NULL

Meander              Smith                          NULL

Dean                 Straight                       NULL

Dirk                 Stringer                       NULL

Johnson              White                          NULL

Akiko                Yokomoto                       NULL

Abraham              Bennet                         Algodata Infosystems

Cheryl               Carson                         Algodata Infosystems



(23 row(s) affected)



无论是否与 publishers 表中的 city 列匹配,LEFT OUTER JOIN 均会在结果中包括 authors 表的全部行。注意:结果中所列的大多数作者都没有相匹配的右表数据,因此,这些行的 pub_name 列包括空值

使用右向外联接

假 设在 city 列上联接 authors 表和 publishers 表。

结果仅仅显示在出版商所在城市居住的作者(本例中为 Abraham Bennet 和 Cheryl Carson)。SQL-92 右向外联接运算符 RIGHT OUTER JOIN 指明:无论第一个表中是否有匹配的数据。结果将包括第二个表中的全部行。



若要在结果中包含全部的出版商,而无论城市中是否还有出版商居住,请使用 SQL-92 右向外联接。以下是 Transact-SQL 右向外联接的查询和结果:



USE pubs

SELECT a.au_fname, a.au_lname, p.pub_name

FROM authors AS a RIGHT OUTER JOIN publishers AS p

   ON a.city = p.city

ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC



以下是结果集:



au_fname             au_lname                 pub_name             

-------------------- ------------------------ -------------------- 

Abraham              Bennet                   Algodata Infosystems

Cheryl               Carson                   Algodata Infosystems

NULL                 NULL                     Binnet & Hardley

NULL                 NULL                     Five Lakes Publishing

NULL                 NULL                     GGG&G

NULL                 NULL                     Lucerne Publishing

NULL                 NULL                     New Moon Books

NULL                 NULL                     Ramona Publishers

NULL                 NULL                     Scootney Books



(9 row(s) affected)



使用谓词(如将联接与常量比較)能够进一步限制外联接。

下例包括同样的右向外联接。但消除销售量低于 50 本的书籍的书名:



USE pubs

SELECT s.stor_id, s.qty, t.title

FROM sales s RIGHT OUTER JOIN titles t

   ON s.title_id = t.title_id

   AND s.qty > 50

ORDER BY s.stor_id ASC



以下是结果集:



stor_id qty    title                                                     

------- ------ --------------------------------------------------------- 

(null) (null) But Is It User Friendly?                                   

(null) (null) Computer Phobic AND Non-Phobic Individuals: Behavior 

            Variations                  

(null) (null) Cooking with Computers: Surreptitious Balance Sheets       

(null) (null) Emotional Security: A New Algorithm                        

(null) (null) Fifty Years in Buckingham Palace Kitchens                  

7066   75     Is Anger the Enemy?

(null) (null) Life Without Fear                                          

(null) (null) Net Etiquette                                              

(null) (null) Onions, Leeks, and Garlic: Cooking Secrets of the 

            Mediterranean                  

(null) (null) Prolonged Data Deprivation: Four Case Studies              

(null) (null) Secrets of Silicon Valley                                  

(null) (null) Silicon Valley Gastronomic Treats                          

(null) (null) Straight Talk About Computers                              

(null) (null) Sushi, Anyone?                                             

(null) (null) The Busy Executive's Database Guide                        

(null) (null) The Gourmet Microwave                                      

(null) (null) The Psychology of Computer Cooking                         

(null) (null) You Can Combat Computer Stress!                            



(18 row(s) affected)



有关谓词的很多其它信息,请參见 WHERE。 



使用完整外部联接

若 要通过在联接结果中包含不匹配的行保留不匹配信息,请使用完整外部联接。

Microsoft® SQL Server™ 2000 提供完整外部联接运算符 FULL OUTER JOIN。无论还有一个表是否有匹配的值,此运算符都包含两个表中的全部行。



如果在 city 列上联接 authors 表和 publishers 表。结果仅仅显示在出版商所在城市居住的作者(本例中为 Abraham Bennet 和 Cheryl Carson)。SQL-92 FULL OUTER JOIN 运算符指明:无论表中是否有匹配的数据,结果将包含两个表中的全部行。

若要在结果中包含全部作者和出版商,而无论城市中是否有出版商或者出版商是否住在同一个城市。请使用完整外部联接。

以下是 Transact-SQL 完整外部联接的查询和结果:



USE pubs

SELECT a.au_fname, a.au_lname, p.pub_name

FROM authors a FULL OUTER JOIN publishers p

   ON a.city = p.city

ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC



以下是结果集:



au_fname             au_lname                     pub_name             

-------------------- ---------------------------- -------------------- 

Reginald             Blotchet-Halls               NULL

Michel               DeFrance                     NULL

Innes                del Castillo                 NULL

Ann                  Dull                         NULL

Marjorie             Green                        NULL

Morningstar          Greene                       NULL

Burt                 Gringlesby                   NULL

Sheryl               Hunter                       NULL

Livia                Karsen                       NULL

Charlene             Locksley                     NULL

Stearns              MacFeather                   NULL

Heather              McBadden                     NULL

Michael              O'Leary                      NULL

Sylvia               Panteley                     NULL

Albert               Ringer                       NULL

Anne                 Ringer                       NULL

Meander              Smith                        NULL

Dean                 Straight                     NULL

Dirk                 Stringer                     NULL

Johnson              White                        NULL

Akiko                Yokomoto                     NULL

Abraham              Bennet                       Algodata Infosystems

Cheryl               Carson                       Algodata Infosystems

NULL                 NULL                         Binnet & Hardley

NULL                 NULL                         Five Lakes Publishing

NULL                 NULL                         GGG&G

NULL                 NULL                         Lucerne Publishing

NULL                 NULL                         New Moon Books

NULL                 NULL                         Ramona Publishers

NULL                 NULL                         Scootney Books



(30 row(s) affected)

SQL:OUTER JOIN使用方法具体解释的更多相关文章

  1. SQL OUTER JOIN

    When we want to select out all the record from two table, no matter it's present at second table or ...

  2. 对于SQL的Join,在学习起来可能是比较乱的。我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚。Coding Horror上有一篇文章,通过文氏图 Venn diagrams 解释了SQL的Join。我觉得清楚易懂,转过来。

     对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚.Codi ...

  3. sql server 本机编译存储过程(内存优化表) 绕过不支持FULL OUTER JOIN 的限制的方法

    将FULL OUTER JOIN 转成left join,right join 和 union select * from A ID NAME4 Spaghetti1 Pirate2 Monkey3 ...

  4. 图解SQL的inner join(join)、left join、right join、full outer join、union、union all的区别

    对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚.Codin ...

  5. SQL 查询条件放在LEFT OUTER JOIN 的ON语句后与放在WHERE中的区别

    这两种条件放置的位置不同很容易让人造成混淆,以致经常查询出莫名其妙的结果出来,特别是副本的条件与主表不匹配时,下面以A,B表为例简单说下我的理解. 首先要明白的是: 跟在ON 后面的条件是对参与左联接 ...

  6. 图解SQL的inner join、left join、right join、full outer join、union、union all的区别【转载】

    对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚.Codin ...

  7. SQL中的left outer join,inner join,right outer join用法详解

    这两天,在研究SQL语法中的inner join多表查询语法的用法,通过学习,发现一个SQL命令,竟然涉及到很多线性代数方面的知识,现将这些知识系统地记录如下: 使用关系代数合并数据1 关系代数合并数 ...

  8. SQL Server 2008 R2——使用FULL OUTER JOIN实现多表信息汇总

    =================================版权声明================================= 版权声明:原创文章 谢绝转载  请通过右侧公告中的“联系邮 ...

  9. SQL中inner join、outer join和cross join的区别

    对于SQL中inner join.outer join和cross join的区别简介:现有两张表,Table A 是左边的表.Table B 是右边的表.其各有四条记录,其中有两条记录name是相同 ...

随机推荐

  1. 我为什么喜欢Go语言

    从2000年至今,也写了11年代码了,期间用过VB.Delphi.C#.C++.Ruby.Python,一直在寻找一门符合自己心意和理念的 语言.我很在意写代码时的手感和执行的效率,所以在Go出现之前 ...

  2. MSSQL 让排序更方便灵活

    SQL: SELECT * FROM table1 ORDER BY CASE WHEN field=value THEN 1 ELSE 0 END (ASC/DESC) 是不是很方便呢,哈哈

  3. POJ 3264.Balanced Lineup-RMQ(ST)详解

    先写一道水题的博客,为后面要写的博客做一个铺垫. ヾ(◍°∇°◍)ノ゙ RMQ(Range Minimum/Maximum Query),即区间最值查询,对于长度为n的数列A,回答若干询问RMQ(A, ...

  4. 链式前向星DFS

    本文链接:http://www.cnblogs.com/Ash-ly/p/5399057.html 采用链式前向星存图的DFS: #include <iostream> #include ...

  5. Jmeter插件之PerfMon监控插件使用说明

    PerfMon是Jmeter用来监控系统资源的一款插件,可以用来监控系统的cpu.内存.I/O等性能指标. 首先是Jmeter的插件安装,需要先下载JMeter Plugins Manager这个插件 ...

  6. Spfa【P1813】拯救小tim_NOI导刊2011提高(02)

    Description 小tim在游乐场,有一天终于逃了出来!但是不小心又被游乐场的工作人员发现了„„所以你的任务是安全地把小tim护送回家.但是,A市复杂的交通状况给你出了一大难题. A市一共有n个 ...

  7. 又是一年NOIP然鹅我考的是高数(虽然我没打并且内容与NOIP无关)(手动滑稽)

    好长时间没有写过总结了.也是高三结束,自招结束.成功的由国宝变为四害,整个人也是完全放松的,或者说是放肆的. 整个暑假都是游戏睡觉,游戏睡觉,也没有干什么有意义的事.有人说别人都在学习大一课程的时候我 ...

  8. 三. Java类与对象8.再谈Java包

    在Java中,为了组织代码的方便,可以将功能相似的类放到一个文件夹内,这个文件夹,就叫做包. 包不但可以包含类,还可以包含接口和其他的包. 目录以"\"来表示层级关系,例如 E:\ ...

  9. Apache压力(并发)测试工具ab的使用教程收集

    说明:用ab的好处,在处理多并发的情况下不用自己写线程模拟.其实这个世界除了LoadRunner之外还是有很多方案可以选择的. 官网: http://httpd.apache.org/(Apache服 ...

  10. DotnetBrowser高级教程-(5)使用内置的MVC UI框架-EasyMvc

    如果DotnetBrowser只是实现了内置chrome浏览器和web/web socket server,似乎还不是很完美.因此,最新的DotnetBrowser已经内置对easy mvc控件的支持 ...