ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 那些语句使用cardinality feedback

那些语句使用cardinality feedback

原创 Linux操作系统 作者:lfree 时间:2014-01-22 15:14:09 0 删除 编辑

[20140122]那些语句使用cardinality feedback.txt

cardinality feedback是11G的新特性,昨天别人问一个问题,在11G下如何知道那些sql语句使用了cardinality feedback。
实际上这些信息保存在v$sql_plan或者DBA_HIST_SQL_PLAN的other_xml里面,里面的信息是XML格式的,对这些语句如何写我自、
己从来记不住。

简单一点:
select * from v$sql_plan where other_xml like '%cardinality_feedback%' ;
或者
select * from DBA_HIST_SQL_PLAN where other_xml like '%cardinality_feedback%' ;


google一些文档,看了一些自己写的一篇blog:
http://blog.itpub.net/267265/viewspace-753102/


很容易写:
/* Formatted on 2014/1/22 15:02:15 (QP5 v5.252.13127.32867) */
SELECT p.sql_id,
       EXTRACTVALUE (h.COLUMN_VALUE, '/info') lvl,
       EXTRACTVALUE (h.COLUMN_VALUE, '/info/@type')
  FROM v$sql_plan p,
       TABLE (
          XMLSEQUENCE (EXTRACT (xmltype (p.other_xml), '/other_xml/info'))) h
WHERE     p.other_xml IS NOT NULL
       AND EXTRACTVALUE (h.COLUMN_VALUE, '/info/@type') LIKE
              'cardinality_feedback';

--实际上利用这个脚本也可以查询其他特性。比如dynamic_sampling,12c的this is an adaptive plan等等。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/267265/viewspace-1074098/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
熟悉oracle相关技术,擅长sql优化,rman备份与恢复,熟悉linux shell编程。

注册时间:2008-01-03

  • 博文量
    2485
  • 访问量
    6290641