oracle数据库 清除执行计划

如果有特定sql用如下方法

1
2
3
4
5
SQL> SELECT ADDRESS,HASH_VALUE FROM V$SQLAREA WHERE ROWNUM<=1;
 
ADDRESS      HASH_VALUE
---------------- ----------
000000006B734450 1227751471r

SQL> EXEC DBMS_SHARED_POOL.PURGE('000000006B734450,1227751471','C'); C表示的是游标

PL/SQL procedure successfully completed.

快速清空一个表中的执行计划

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
BEGIN
  DBMS_STATS.GATHER_TABLE_STATS(ownname          => 'C##HRZ',
                                tabname          => 'BRICKS',
                                estimate_percent => 100,                         看下边优化建议
                                method_opt       => 'for all columns size auto', 自动判断是否收集直方图
                                no_invalidate    => FALSE, 是游标失效
                                degree           => 1,     根据自己cpu数量
                                granularity      => 'ALL', 收集分区表
                                cascade          => TRUE); 收集索引
END;
/
 
estimate_percent :
<1GB 建议采样比100%
1GB~5GB 建议采样比50%
>5GB 建议采样比30%

  

posted @   蚌壳里夜有多长  阅读(51)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示