1. 程式人生 > >SQL多表查詢優化 高效率SQL語句 11條原則

SQL多表查詢優化 高效率SQL語句 11條原則

)重點關注ORACLE的解析器按照從右到左的順序處理FROM子句中的表名,因此FROM子句中寫在最後的表(基礎表 driving table)將被最先處理. FROM子句中包含多個表的情況下,你必須選擇記錄條數最少的表作為基礎表.ORACLE處理多個表時, 會運用排序及合併的方式連線它們.首先,掃描第一個表(FROM子句中最後的那個表)並對記錄進行派序,然後掃描第二個表(FROM子句中最後第二個表),最後將所有從第二個表中檢索出的記錄與第一個表中合適記錄進行合併.
例如:       TAB1 16,384 條記錄表 TAB2 1       條記錄選擇TAB2作為基礎表 (最好的方法)
select count(*) from tab1,tab2   
執行時間0.96秒選擇TAB2作為基礎表 (不佳的方法)
select count(*) from tab2,tab1   
執行時間26.09秒如果有3個以上的表連線查詢, 那就需要選擇交叉表(intersection table)作為基礎表, 交叉表是指那個被其他表所引用的表.
例如:    EMP表描述了LOCATION表和CATEGORY表的交集.
SELECT *
FROM LOCATION L ,
CATEGORY C,
EMP E
WHERE E.EMP_NO BETWEEN 1000 AND 2000
AND E.CAT_NO = C.CAT_NO
AND E.LOCN = L.LOCN
將比下列SQL更有效率
SELECT *
FROM EMP E ,
LOCATION L ,
CATEGORY C
WHERE   E.CAT_NO = C.CAT_NO
AND E.LOCN = L.LOCN
AND E.EMP_NO BETWEEN 1000 AND 2000