SQL優化常用方法3

inzaghi1984發表於2017-12-13
  1. 共享SQL語句
    為了不重複解析相同的SQL語句,在第一次解析之後, ORACLE將SQL語句存放在記憶體中.這塊位於系統全域性區域SGA (system global area)的共享池(shared buffer pool)中的記憶體可以被所有的資料庫使用者共享. 因此,當你執行一個SQL語句(有時被稱為一個遊標)時,如果它和之前的執行過的語句完全相同, ORACLE就能很快獲得已經被解析的語句以及最好的執行路徑.ORACLE的這個功能大大地提高了SQL的執行效能並節省了記憶體的使用.可惜的是ORACLE只對簡單的表提供高速緩衝(cache buffering) ,這個功能並不適用於多表連線查詢. 資料庫管理員必須在init.ora中為這個區域設定合適的引數,當這個記憶體區域越大,就可以保留更多的語句,當然被共享的可能性也就越大了. 當你向ORACLE 提交一個SQL語句,ORACLE會首先在這塊記憶體中查詢相同的語句. 這裡需要註明的是,ORACLE對兩者採取的是一種嚴格匹配,要達成共享,SQL語句必須完全相同(包括空格,換行等).

共享的語句必須滿足三個條件:
A. 字元級的比較: 當前被執行的語句和共享池中的語句必須完全相同. 例如:
SELECT FROM EMP; 和下列每一個都不同SELECT from EMP; Select From Emp; SELECT FROM EMP;
B. 兩個語句所指的物件必須完全相同: 例如:
使用者 物件名 如何訪問
Jack sal_limit private synonym
Work_city public synonym
Plant_detail public synonym
Jill sal_limit private synonym
Work_city public synonym
Plant_detail table owner
考慮一下下列SQL語句能否在這兩個使用者之間共享.
SQL 能否共享 原因
select max(sal_cap) from sal_limit; 不能 每個使用者都有一個private synonym – sal_limit , 它們是不同的物件
select count(*0 from work_city where sdesc like `NEW%`; 能 兩個使用者訪問相同的物件public synonym – work_city
select a.sdesc,b.location from work_city a , plant_detail b where a.city_id = b.city_id 不能 使用者jack 通過private synonym訪問plant_detail 而jill 是表的所有者,物件不同.
C. 兩個SQL語句中必須使用相同的名字的繫結變數(bind variables) 例如:
第一組的兩個SQL語句是相同的(可以共享),而第二組中的兩個語句是不同的(即使在執行時,賦於不同的繫結變數相同的值)

  1. select pin , name from people where pin = :blk1.pin;
  2. pin , name from people where pin = :blk1.pin;
  3. select pin , name from people where pin = :blk1.ot_ind;
  4. pin , name from people where pin = :blk1.ov_ind;


相關文章