ITPub博客

首页 > 数据库 > Oracle > oracle固定对象到共享池

oracle固定对象到共享池

原创 Oracle 作者:水逸冰 时间:2019-07-06 12:09:00 0 删除 编辑

    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/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
精通oracle和linux,热衷于研究oracle,擅长shell和Python编程,喜欢自动化运维。

注册时间:2017-08-05

  • 博文量
    91
  • 访问量
    77764