oracle 軟解析與硬解析

(1)sql解析

解析分爲軟解析與硬解析。
SQL語句有dml和ddl之分,ddl執行硬解析,dml若在share pool中存在且可被共享,執行軟解析。
     軟解析無需選擇與生成執行計劃,減小開銷,實際應該儘量避免使用綁定變量硬解析。

 

(2)解析步驟

1.語法判斷

判斷sql語句是否拼寫錯誤

2.語義判斷

判斷對象是否存在,用戶對對象是否有權限

3.查找share pool 確定硬解析或軟解析


  • 判斷是否同一sql語句,大小寫及空格等都要完全相同
  • 判斷是否同一物理對象,如不同用戶下的同名表
  • 判斷是否同一優化器,如first rows 與 all rows不同

符合上面三個條件,進行軟解析

 

注:網上有個誤區,先進行share pool 查找,若是軟解析則不進行1、2步驟,據官方文檔,這是不正確的。詳見http://docs.oracle.com/cd/E11882_01/server.112/e40540/sqllangu.htm#CNCPT88919

 

(3)軟解析:

條件:在share pool中存在,且可被共享

步驟:1.執行執行計劃

 

(3)硬解析

條件:在share pool 中不存在或存在但不可被共享

步驟:1.選擇執行計劃

2.產生執行計劃

3.執行執行計劃
發佈了26 篇原創文章 · 獲贊 1 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章