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');
oracle固定对象到共享池
来源:这里教程网
时间:2026-03-03 13:57:03
作者:
编辑推荐:
- oracle固定对象到共享池03-03
- [20190706]Same dog, different leash – functions in SQL.txt03-03
- 管理(004):密码文件 & 用户03-03
- AWR TOP SQL实现03-03
- 解决Win7下Jdeveloper(OAF) 黑屏、卡顿、反应慢的 方法!03-03
- java.lang.IllegalArgumentException:There is no column named SYS_NC00010$03-03
- 关于oracle的Spool命令03-03
- [20190703]12c Hybrid histogram.txt03-03
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- 管理(004):密码文件 & 用户
管理(004):密码文件 & 用户
26-03-03 - java.lang.IllegalArgumentException:There is no column named SYS_NC00010$
- 关于oracle的Spool命令
关于oracle的Spool命令
26-03-03 - Debian电源管理优化(提升Linux系统续航与节能效率的完整指南)
Debian电源管理优化(提升Linux系统续航与节能效率的完整指南)
26-03-03 - rac 添加第二public ip 和 vip
rac 添加第二public ip 和 vip
26-03-03 - APP_CALCULATE.RUNNING_TOTAL用法
APP_CALCULATE.RUNNING_TOTAL用法
26-03-03 - Oracle 12C RAC CDB数据库部署
Oracle 12C RAC CDB数据库部署
26-03-03 - 阿里云POLARDB 2.0重磅来袭!为何用户如此的期待?
阿里云POLARDB 2.0重磅来袭!为何用户如此的期待?
26-03-03 - ORACLE 12C opatch fuser与ChecksystemCommandAvailable failed
- 静默安装Oracle建库时报Template General Purpose does not exist
