Oracle 11g如何清除share pool中某条SQL的执行计划

教程发布:风哥 教程分类:ITPUX技术网 更新日期:2022-02-12 浏览学习:1645

[color=#362e2b] 以前在10g[color=#df3434]http://lib.csdn.net/base/mysql]数据库上,如果遇到绑定窥探导致执行计划慢的情况,想要清除某条SQL的执行计划,让它硬解析,找了很久都没有找到直接操作share pool的方法(总不能alter system flush shared_pool),只能通过对表ddl使SQL硬解析。现在终于找到了,使用sys.dbms_shared_pool.purge,在11g下可以直接使用,但在10g上需要alter session set events '5614566 trace name context forever'。[color=#362e2b]SQL> select * from v$version;[color=#362e2b]BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE 11.2.0.1.0 Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production[color=#362e2b]
SQL> drop table test purge;
[color=#362e2b]
SQL> create table test as select * from dba_objects;
[color=#362e2b]
SQL> exec dbms_stats.gather_table_stats(user,'test');
[color=#362e2b]
SQL> select /*gg*/count(*) from test;
COUNT(*)
----------
79747
[color=#362e2b]
SQL> col SQL_TEXT format a35
SQL> col ADDRESS format a18
SQL> col HASH_VALUE format a10
SQL> select s.SQL_TEXT, s.ADDRESS, s.HASH_VALUE||''
from v$sqlarea s
where sql_text like 'select /*gg*/count(*) from test%';
[color=#362e2b]
SQL_TEXT ADDRESS S.HASH_VALUE||''
----------------------------------- ------------------ --------------------------------
select /*gg*/count(*) from test 0000000300B06D70 728448230
[color=#362e2b]
SQL> exec sys.dbms_shared_pool.purge('0000000300B06D70,728448230','c');
PL/SQL 过程已成功完成。
[color=#362e2b]
SQL> select s.SQL_TEXT, s.ADDRESS, s.HASH_VALUE||''
from v$sqlarea s
where sql_text like 'select /*gg*/count(*) from test%';
未选定行

本文标签:
网站声明:本文由风哥整理发布,转载请保留此段声明,本站所有内容将不对其使用后果做任何承诺,请读者谨慎使用!
【上一篇】
【下一篇】