oracle怎么固定对象到共享池


本篇内容主要讲解“oracle怎么固定对象到共享池”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“oracle怎么固定对象到共享池”吧!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_valueb.对于一个父游标下面的多个子游标,它们的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’);

到此,相信大家对“oracle怎么固定对象到共享池”有了更深的了解,不妨来实际操作一番吧!这里是百云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

COUNT(*)———- 36MING@ming(MING)> set line 100MING@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’);

到此,相信大家对“oracle怎么固定对象到共享池”有了更深的了解,不妨来实际操作一番吧!这里是百云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

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.k免费云主机域名eep(‘000000007267DA48,2863430698′,’C’);解除游标固定exec sys.dbms_shared_pool.unkeep(‘000000007267DA48,2863430698′,’C’);到此,相信大家对“oracle怎么固定对象到共享池”有了更深的了解,不妨来实际操作一番吧!这里是百云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

相关推荐: ilom中怎么创建snapshot

ilom中怎么创建snapshot,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。配置Snapshot选项和生成路径->set /SP/diag/snapshot dataset=[nor…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 01/05 22:31
下一篇 01/06 09:37