ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 如何查看哪些SQL使用了动态采样?

如何查看哪些SQL使用了动态采样?

原创 Linux操作系统 作者:wei-xh 时间:2013-09-29 14:04:59 0 删除 编辑
以下2个SQL在11.2.0.3下都能正常运行,11.1.0.7可能会遭遇错误,具体原因还没深入研究
select p.sql_id,  extractvalue(h.column_value,'/info') lvl
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') = 'dynamic_sampling';


select p.sql_id, t.val
from   v$sql_plan p
,      xmltable('for $i in /other_xml/info
                 where $i/@type eq "dynamic_sampling"
                 return $i'
                passing xmltype(p.other_xml)
                columns attr varchar2(50) path '@type',
                        val  varchar2(50) path '/') t
where  p.other_xml is not null;

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

请登录后发表评论 登录
全部评论
Oracle ACE组成员,DBGeeK用户组发起人。曾在DTCC、ORACLE技术嘉年华、Gdevops等公开场合做过数据库技术专题分享,2017年应Oracle邀请在世界最大的数据库会议OOW上做技术分享。组织翻译了《拨云见日,解密Oracle ASM内核》一书。

注册时间:2009-07-04

  • 博文量
    422
  • 访问量
    2301733