外連線的一些總結
外連線的一些總結
[@more@]外連線的一些總結
外連線擴充套件簡單連線的結果,一個外連線返回的值不僅是所有滿足連線條件的行,同時還有為NULL值的行。
建立試驗表A、B
SQL> select * from a; A1 A2 ---------- -- 1 1 2 3 3 SQL> select * from b; B1 B2 ---------- -- 1 1 2 2 SQL> select * from a,b where a2=b2; A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 SQL> select * from c; C1 C2 ---------- -- 1 1 2 4 3 |
1、對於查詢一個外連線AB兩個表的話,並且返回A表上所有的行,這是一個左連線(left outer join),在FROM上使用LEFT JOIN,或者在where語句的B表的列上使用(+)。對於A上有一些行並不和表B匹配,Oracle會返回空值。
SQL> select * from a,b where a2=b2(+); A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 2 3 3 SQL> select * from a left outer join b on a2=b2; A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 2 3 3 |
2、對於查詢一個外連線AB兩個表的話,並且返回B表上所有的行,這是一個右連線(right outer join),在FROM上使用RIGHT JOIN,或者在where語句的A表的列上使用(+)。對於B上有一些行並不和表A匹配,Oracle會返回空值。
SQL> select * from a,b where a2(+)=b2; A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 2 2 SQL> select * from a right outer join b on a2=b2; A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 2 2 |
3、對於查詢一個外連線AB兩個表的話,並且返回A和B表上所有的行,這是一個全外連線(full outer join),在FROM上使用full JOIN。
SQL> select * from a full outer join b on a2=b2; A1 A2 B1 B2 ---------- -- ---------- -- 1 1 1 1 2 3 3 2 2 |
4、在查詢語句的FROM子句中有連線語法的時候是不能指定(+)操作的。
5、(+)只能用在WHERE子句中。
6、如果A、B是一種多連線狀態的連線,需要在所有的條件上使用(+)。
7、外連線不能對自身進行。
SQL> select * from a where a2=a2(+); select * from a where a2=a2(+) * 第 1 行出現錯誤: ORA-01416: 兩表無法彼此外部連線 但是可以這樣使用: SQL> select * from a t1,a t2 where t1.a2=t2.a2(+); A1 A2 A1 A2 ---------- -- ---------- -- 1 1 1 1 3 3 3 3 2 |
8、(+)操作只能用於列,不能適用於表示式。
9、一個條件包含(+)操作不能使用OR邏輯操作與其他條件聯合使用。
10、條件不能用IN來比較一個帶有操作的列。
11、不能在其子查詢上比較任何帶有(+)操作的列。
外連線是在SQL最佳化上難點之一,很多程式由於外連線的使用,會造成很多效能問題,這裡簡要總結以下幾個存在的外連線使用不對的地方。
1、外連線的使用不當的地方
SQL> select * from a,b,c where a2(+)=b2 and a2=c2; A1 A2 B1 B2 C1 C2 ---------- -- ---------- -- ---------- -- 1 1 1 1 1 1 SQL> select * from a,b,c where a2(+)=b2 and b2=c2; A1 A2 B1 B2 C1 C2 ---------- -- ---------- -- ---------- -- 1 1 1 1 1 1 在這兩個查詢來看都有一個共同的特點,由於ab表之間有外連線的關係,但是ab表和其他表之間還是有限制條件,這樣外連線就沒有意義了,但是由於外連線的存在,最佳化器就會被限制,很多查詢計劃就會因為這個外連線的存在而不被最佳化器考慮。所以在這種情況下,應該將這個外連線刪除。 |
2、遞推的關係
SQL> select * from a,b,c where a2(+)=b2 and b2(+)=c2; A1 A2 B1 B2 C1 C2 ---------- -- ---------- -- ---------- -- 1 1 1 1 1 1 2 4 3 Ab表之間有外連線,bc之間有外連線,既A要求B表的所有的行,而B要求C表的所有的行,最終的結果只是得到C表的所有的行。 SQL> select * from a,b,c where a2(+)=b2 and b2=c2(+); A1 A2 B1 B2 C1 C2 ---------- -- ---------- -- ---------- -- 1 1 1 1 1 1 2 2 Ab表之間有外連線,bc之間有外連線,既A要求B表的所有的行,而C要求B表的所有的行,最終的結果只是得到B表的所有的行 |
總結以上兩條,可以看到外連線是有遞推的關係的,不能相互衝突。
SQL> select * from a,b,c where a2(+)=b2 and a2(+)=c2; select * from a,b,c where a2(+)=b2 and a2(+)=c2 * 第 1 行出現錯誤: ORA-01417: 表可以外部連線到至多一個其它的表 這裡就是Ab表之間有外連線,ac之間也有外連線,就會出現問題 |
同時如果兩個有外連線的表,無論其中哪一個和其他表有等值的限制條件的產生的時候,就會出現外連線無用的情況,但是這樣就會造成效能問題。
外連線的改寫
對於一個查詢:
Select …,outer_joined_to_table.column From some_table. outer_joined_to_table Where …= outer_joined_to_table(+) |
可以改寫為:
Select …,(select column from outer_joined_to_table where …) from some_table; |
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/222350/viewspace-908029/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle左外連線、右外連線、完全外連線以及(+)號用法Oracle
- 一些開發chrome外掛用到的API總結ChromeAPI
- redux的一些外掛總結(redux-actions,reselect)Redux
- 一些有用的連結
- sql 內連線和外連線SQL
- Smack 開發總結(一)管理連線Mac
- Redux的一些總結Redux
- MYSQL語法:左連線、右連線、內連線、全外連線MySql
- MySQL筆記3——內連線/外連線、多表連線MySql筆記
- 內聯,左外聯,右外聯,全連線,交叉連線 的區別
- 正則的一些總結
- Flash安全的一些總結
- 簡單總結nodejs處理tcp連線的核心流程NodeJSTCP
- ISP 連結總結
- 一些來不及整理的連結
- 友情連結外掛
- ORACLE會話連線程式三者總結Oracle會話線程
- 【經典】連線oracle的總結(關於tnsname和監聽)Oracle
- Ajax技術的一些總結
- 學習 CodeWhisperer 的一些總結
- 連結推廣的一些知識
- 20240628總結(圖的連通性)
- 線性表(陣列、連結串列、佇列、棧)詳細總結陣列佇列
- 3.DQL資料查詢語言(內連線,外連線,自連線)
- larabbs 使用的一些擴充總結
- 總結下 javascript 中的一些小技巧JavaScript
- 2020年的一些思考和總結
- 關於Mysql使用的一些總結MySql
- GoLang中字串的一些使用總結Golang字串
- MySql關於鎖的一些總結MySql
- redo log 和 binlog 的一些總結
- 小白對python的一些概念的總結Python
- 連結串列基礎總結
- Mysql——內外連線,事物,索引MySql索引
- 一些Q複製實踐的連結
- 短連結的一些技術知識
- 詭異的druid連結池連結斷開故障經驗總結UI
- Laravel專案部署到線上需要注意的一些問題總結Laravel
- golang的比較好的一些超連結Golang