Oracle 11g如何清除share pool中某条SQL的执行计划
2015-02-13 18:28
585 查看
以前在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%';
未选定行
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%';
未选定行
相关文章推荐
- oracle如何产生sql 执行计划(一)
- 简单讨论在11G,10G中如何稳定SQL执行计划(一)
- oracle如何分析sql执行计划
- 如何分析ORACLE的SQL执行计划
- Oracle技术之如何使用ordered提示改变SQL执行计划
- oracle sql的执行计划如何查看
- 使用dbms_shared_pool.purge清除共享池中的SQL执行计划
- oracle 10g 刷新share pool里的执行计划
- Oracle 如何根据动态性能视图来查看某条SQL语句的执行计划
- 如何获取Oracle share pool中没有使用绑定变量的SQL
- 【转】如何查看oracle sql执行计划
- Oracle 11g 中SQL 执行计划不稳定
- oracle 11g BaseLine(基线)指定application中不可修改sql的执行计划
- 简单讨论在11G,10G中如何稳定SQL执行计划(二)
- Oracle如何查看SQL实际执行计划
- 查看Oracle执行计划的几种方法 / oracle中DateTime类型的字段,建立索引后,查寻时索引如何生效?/ oracle 中sql语句怎么加多个强制索引
- 如何清除某条SQL的执行计划
- Oracle 数据库如何搜集指定SQL的执行计划和解决过程中的ORA-00904错误
- oracle如何获得客户端sql执行计划以便优化sql(三)
- 如何查看oracle sql执行计划