oracle固定物件到共享池

水逸冰發表於2019-07-06

    PL/SQL一般來說很大,將這樣的物件裝載到共享池中,需要去尋找大段的連續記憶體空間,如果連續裝載的話,那麼必然會將很多熱點記憶體age out出共享池。這樣一來勢必會影響資料庫效能。

所以將常用的PL/SQL或者SQL遊標固定到共享池中,可以解決上述問題。包括可能出現的ORA-04031報錯。

1.固定PL/SQL到共享池

SYS@cdbtest1(MING)> exec sys.dbms_shared_pool.keep('ming.p_hello','P');


PL/SQL procedure successfully completed.


可以通過下述sql的keep欄位檢視是否固定到共享池中。

SELECT * FROM v$db_object_cache where owner='MING' and  TYPE = 'PROCEDURE';


解決固定的方法:

SYS@cdbtest1(MING)> exec sys.dbms_shared_pool.unkeep('ming.p_hello','P');


PL/SQL procedure successfully completed.



2.固定sql遊標到共享池的方法

對於固定sql遊標,需要明白如下:

a.固定遊標需要得到遊標的address和hash_value

b.對於一個父遊標下面的多個子遊標,它們的address和hash_value都是一樣的


MING@ming(MING)> variable p number;

MING@ming(MING)> exec :p := 10;


PL/SQL procedure successfully completed.


MING@ming(MING)> select /*test2*/ count(*)  from t1 where a<:p;


  COUNT(*)

----------

        36


MING@ming(MING)> set line 100

MING@ming(MING)> select sql_id,sql_text from v$sql where sql_text like '%test2%';


SQL_ID        SQL_TEXT

------------- ----------------------------------------------------------------------

1anf7skpasz1a select /*test2*/ count(*)  from t1 where a<:p

5ybns6qudvgcm select sql_id,sql_text from v$sql where sql_text like '%test2%'


MING@ming(MING)> select sql_id,address,hash_value,version_count from v$sqlarea where sql_id='1anf7skpasz1a';


SQL_ID        ADDRESS          HASH_VALUE VERSION_COUNT

------------- ---------------- ---------- -------------

1anf7skpasz1a 000000007267DA48 2863430698             1



固定遊標

exec sys.dbms_shared_pool.keep('000000007267DA48,2863430698','C');


解除遊標固定

exec sys.dbms_shared_pool.unkeep('000000007267DA48,2863430698','C');




來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31480688/viewspace-2649750/,如需轉載,請註明出處,否則將追究法律責任。

相關文章