用dbms_shared_pool.purge清除执行计划

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

以前在Oracle 10g数据库上,如果遇到绑定窥探导致执行计划慢的情况,想要清除某条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'。

SQL> select * from v$version;

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

SQL> drop table test purge;

SQL> create table test as select * from dba_objects;

SQL> exec dbms_stats.gather_table_stats(user,'test');

SQL> select /*gg*/count(*) from test;

COUNT(*)

----------

79747

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%';

SQL_TEXT                            ADDRESS      S.HASH_VALUE||''

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

select /*gg*/count(*) from test  0000000300B06D70  728448230

SQL> exec sys.dbms_shared_pool.purge('0000000300B06D70,728448230','c');

PL/SQL 过程已成功完成。

SQL> select s.SQL_TEXT, s.ADDRESS, s.HASH_VALUE||''

from v$sqlarea s

where sql_text like 'select /*gg*/count(*) from test%';

未选定行

2.用dbms_shared_pool.purge清除执行计划

SQL> SELECT address,hash_value,sql_id

FROM v$sql_plan 

WHERE hash_value='1044487536';

ADDRESS   HASH_VALUE  SQL_ID

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

3027BE24  1044487536   c26zxwhz437bh

SQL> select count(*) from v$sql WHERE hash_value='1044487536';

COUNT(*)

----------

1

--内存中存在这条语句的执行计划。

SQL> exec dbms_shared_pool.purge('3027BE24,1044487536','C'); -----清除执行计划。

PL/SQL 过程已成功完成。

SQL> SELECT address,hash_value,sql_id

FROM v$sql_plan

WHERE hash_value='1044487536';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Running Sun丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值