继上次聊SQL Plan Directives(SPD)可能会造成过量的动态采样之后,我再小结一些关于SPD的使用方法。
(1)SPD的信息,有MMON每隔15分钟刷进数据字典,如果要在15分钟不到前,查询dba_sql_plan_dir_objects和dba_sql_plan_directives,可以先flush强制刷出,再查询:
exec dbms_spd.FLUSH_SQL_PLAN_DIRECTIVE;
(2)如何关联sql id和directive id,可以在display_cursor时使用format=>’+METRICS’
conn test/test
explain plan for
select
cust_id, channel_id, product
from big_table
where product = 'Nokia'
and channel_id = 1
order by product;
select* from table(dbms_xplan.display(null,null,'+METRICS'));
sqlid_dirid
(3)ALTER_SQL_PLAN_DIRECTIVE可以改变ENABLED和AUTO_DROP的属性。
dbms_spd.alter_sql_plan_directive(14130932452940503769,'ENABLED','NO');
exec dbms_spd.alter_sql_plan_directive(14130932452940503769,'AUTO_DROP','NO');
(4)SPD默认保留时间是53周。可以如下来看:
SELECT DBMS_SPD.GET_PREFS('SPD_RETENTION_WEEKS') FROM DUAL;
53周之后,可以使用dbms_spd.drop_sql_plan_directive,带null参数,删除所有已经过期的directives。如果要删除某个固定的directive_id,将具体的directive_id替换null即可。
exec dbms_spd.drop_sql_plan_directive(null);
注,auto drop为YES的话,是不理会enable是YES还是NO。
所以可能会出现:enable是设置成NO,一段时间内是不走SPD,不适用动态采样。但是等53周过了之后,即使enable是no,但是auto drop是yes,在清理时被清理掉了。那么,悲剧又来了,被drop掉之后,SPD重新生成,且生成的是enable为YES的。
所以如果要彻底禁用某个SPD,请将enable设置为no的同时,再将auto drop设置为no。
(5)SPD也可以打包传输,见CREATE_STGTAB_DIRECTIVE,PACK_STGTAB_DIRECTIVE和UNPACK_STGTAB_DIRECTIVE。用法和sqlset类似。
万王之王3D铁卫技能加点推荐(铁卫技能加点详解及优化方案,助你成为无敌的王者!)
探秘第五人格佣兵天赋加点技巧(打造最强佣兵,助你成为游戏巅峰)
2026有用的老年人脑力训练游戏有什么 有趣的脑力训练游戏合集推荐
三国杀玩法介绍新手详细攻略(三国杀游戏规则、角色技能、策略技巧全解析!)
《如何有效地训练方舟重爪龙》(掌握关键技巧,打造最强重爪龙!)
《深空之眼》金乌一直飞天教程(探索飞天之谜,追寻深空奥秘)