ITPUX技术网

交流 . 资讯 . 分享
Make progress together!
Oracle数据库DBA高级工程师培训视频
Oracle数据库培训-备份恢复-性能优化-集群容灾
mysql数据库视频教程

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

内容发布:风哥| 发布时间:2016-10-31 11:20:42

以前在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%';
未选定行




上一篇:关于dbms_shared_pool.purge在oracle10g和oracle11g中的使用
下一篇:中间件连接Oracle12c数据库报错ORA-28040: No matching authentication protocol
189070296,150201289

专业提供Oracle数据库服务、主机、存储、备份、中间件等相关技术支持服务,QQ号:176140749
关注ITPUX技术网微信公众号itpux_com  ,了解本站最新技术资料的分享.

欢迎加QQ群,提供超多高质量Oracle/Unix/Linux技术文档与视频教程的下载。

Oracle/MySQL/Linux群4-5:189070296  150201289  
Oracle/MySQL/Linux群6-8:244609803   522261684   522651731
备注:请勿重复加群,另请注明 from itpux

加群分享视频教程部分如下:

1、公开课视频:Oracle/MySQL数据库工程师职业发展前景讲解(免费)
http://edu.51cto.com/course/7015.html

2、51CTO学院Oracle数据库高级工程师培训(高薪就业.课程介绍)
http://edu.51cto.com/px/train/131?xiaotu

3、Oracle DBA数据库高级工程师培训视频课程1.1(系列78套+七大阶段+上千案例)
套餐视频地址: http://edu.51cto.com/topic/1121.html

4、MySQL数据库(终身门徒)套餐:http://edu.51cto.com/sd/1e1a6

回复

使用道具 举报

1框架
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表