微課sql最佳化(16)、表的連線方法(5)-關於Merge Join(排序合連線)
1、原理解釋
2、Merge Join特點
1、每個子節點只會執行一次
2、每個輸入資料集都必須按照連線條件的欄位進行排序
3、由於排序操作,在返回第一條結果前,兩個資料集都必須被完全讀出並排序。
3、 適用場景
Merge Join將兩個表排序,然後將兩個表合併。通常情況下,只有在以下情況發生時,才會使用此種JOIN方式:
1.RBO模式
2.不等價關聯(>,<,>=,<=,<>)
3.HASH_JOIN_ENABLED=false
4.資料來源已排序
4、Merge Join示例
SQL> select /*+ ordered use_merge(a)*/c.cons_no,c.cons_name,a.AMT_YM,a.amt
from ht.c_cons_hash c,ht.a_amt_hash a
where c.cons_no=a.cons_no
and c.cons_name='Hash_Join'
order by 1; 2 3 4 5
Execution Plan
----------------------------------------------------------
Plan hash value: 1313733800
--------------------------------------------------------------------------------------------------------------
| Id | Operation
| Name
| Rows | Bytes |TempSpc| Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT
|
|
12 |
360 |
|
401 (1)| 00:00:05 |
| 1 | MERGE JOIN
|
|
12 |
360 |
|
401 (1)| 00:00:05 |
| 2 | SORT JOIN
|
|
2 |
26 |
|
4 (25)| 00:00:01 |
| 3 | TABLE ACCESS BY INDEX ROWID| C_CONS_HASH
|
2 |
26 |
|
3 (0)| 00:00:01 |
|* 4 | INDEX RANGE SCAN
| IDX_C_CONS_HASH_NAME |
2 |
|
|
1 (0)| 00:00:01 |
|* 5 | SORT JOIN
|
| 59968 |
995K|
3320K|
397 (1)| 00:00:05 |
| 6 | TABLE ACCESS FULL
| A_AMT_HASH
| 59968 |
995K|
|
65 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
4 - access("C"."CONS_NAME"='Hash_Join')
5 - access("C"."CONS_NO"="A"."CONS_NO")
filter("C"."CONS_NO"="A"."CONS_NO")
5、三種連線方式比較
NL: 從一張表中讀取資料,訪問另一張表(通常是索引)來做匹配,nested loops適用的場合是驅動錶行數較小時,效率會更高。
Hash join: 將一個表(通常是小一點的那個表)對連線鍵做hash運算,將Hash結果做為索引值和行資訊儲存到Hash表中,從另一個表中抽取記錄,對連線鍵做hash運算,到Hash表中查詢匹配的行。
Merge Join 是先將關聯表的關聯列各自做排序,然後從各自的排序表中抽取資料,到另一個排序表中做匹配,因為merge join需要做更多的排序,所以消耗的資源更多。 通常情況下,Hash Join會比
Merge Join效能更好。
6、引數文件
《Oracle? Database Performance Tuning Guide 11g Release 2 (11.2)》
《Troubleshooting Oracle Performance》
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31442014/viewspace-2678276/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 微課sql最佳化(15)、表的連線方法(4)-關於Hash Join(雜湊連線)SQL
- Oracle表連線操作——Merge Sort Join(合併排序連線)Oracle排序
- 微課sql最佳化(14)、表的連線方法(3)-關於Nested Loops Join(巢狀迴圈)SQLOOP巢狀
- 排序合併連線(sort merge join)的原理排序
- 微課sql最佳化(13)、表的連線方法(2)-基礎概念SQL
- Oracle的表連線方法(一)排序合併連線Oracle排序
- 微課sql最佳化(12)、表的連線方法(1)-幫助網友最佳化報表SQLSQL
- 表的連線方式:NESTED LOOP、HASH JOIN、SORT MERGE JOIN(轉)OOP
- sql 連線查詢例項(left join)三表連線查詢SQL
- 【SQL】表連線 --半連線SQL
- mysql INNER JOIN、LEFT JOIN、RIGHT JOIN;內連線(等值連線)、左連線、右連線MySql
- Oracle(+)連線與Join連線Oracle
- Oracle表連線操作——Hash Join(雜湊連線)下Oracle
- Oracle表連線操作——Hash Join(雜湊連線)上Oracle
- 兩表連線三:合併連線
- 排序和表連線排序
- 【SQL 學習】表連線--natural join 的一個bugSQL
- 表連線方法
- Oracle的表連線方法(三)雜湊連線Oracle
- 多表連線的三種方式詳解 hash join、merge join、 nested loopOOP
- SQL 三表連線SQL
- 【SQL 效能最佳化】表的三種連線方式SQL
- 連線字串的SQL方法字串SQL
- LINQ系列:LINQ to SQL Join連線SQL
- 關於面向連線與面向無連線
- LEFT JOIN 和JOIN 多表連線
- MySql的join(連線)查詢 (三表 left join 寫法)MySql
- 表連線 join和(+)、union和uion allUI
- 關於java連線SQL資料庫JavaSQL資料庫
- SQL語句中不同的連線JOIN及SQL中join的各種用法SQL
- SQL的四種連線:內連線 左外連線 右外連線 全連線SQL
- 【SQL 學習】表連線SQL
- 【SQL】13 SQL 別名、SQL 連線(JOIN)、SQL INNER JOIN 關鍵字、SQL LEFT JOIN 關鍵字、SQL RIGHT JOIN 關鍵字、SQL FULL OUTER JSQL
- Apache Spark SQL的高階Join連線技術ApacheSparkSQL
- Oracle的表連線方法(二)巢狀迴圈連線Oracle巢狀
- 微課sql最佳化(10)、關於資料訪問方法SQL
- SQL 經典回顧:JOIN 表連線操作不完全指南SQL
- Oracle的表連線方法(七)Oracle