標籤:
選擇最有效順序表名(只有有效基於規則的最佳化)
ORACLE分析器按照訂單處理從右至左FROM在FROM子句中的表名,故FROM寫在最後的表(基礎資料表 driving table)將被最先處理. 在FROM子句中包括多個表的情況下,你必須選擇記錄條數最少的表作為基礎資料表.當ORACLE處理多個表時, 會運用排序及合并的方式串連它們.首先,掃描第一個表(FROM子句中最後的那個表)並對記錄進行派序,然後掃描第二個表(FROM子句中最後第二個表),最後將全部從第二個表中檢索出的記錄與第一個表中合適記錄進行合并.
比如:
表 TAB1:16,384 條記錄、表 TAB2:1 條記錄
選擇TAB2作為基礎資料表 (最好的方法):已耗用時間0.96秒
select count(*) from tab1,tab2
選擇TAB2作為基礎資料表 (不佳的方法):已耗用時間26.09秒
select count(*) from tab2,tab1
假設有3個以上的表串連查詢, 那就須要選擇交叉表(intersection table)作為基礎資料表, 交叉表是指那個被其它表所引用的表.
比如:
EMP表描寫敘述了LOCATION表和CATEGORY表的交集.
SELECT * FROM LOCATION L , CATEGORY C, EMP E WHERE E.EMP_NO BETWEEN 1000 AND 2000AND E.CAT_NO = C.CAT_NOAND E.LOCN = L.LOCN
將比下列SQL更有效率:
SELECT * FROM EMP E ,LOCATION L , CATEGORY CWHERE E.CAT_NO = C.CAT_NOAND E.LOCN = L.LOCNAND E.EMP_NO BETWEEN 1000 AND 2000
小註:
本文摘自百度文庫,詳細連結木有找到。抱歉。
著作權聲明:筆者:jiankunking 資源:http://blog.csdn.net/jiankunking 本文著作權歸作者和CSDN共同擁有。歡迎轉載。但是,如果沒有從本節宣布提交許可權必須保留,並串連到原來的文章頁給出視在位置。
Oracle效能最佳化順序表名稱來選擇最有效學習筆記