1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

今天主要向大家介绍的是如何正确的使用Oracle Sql Trace与10046 event来对Oracle数据库的性能进行相关的诊断,我们大家都知道level超过1的10046事件时通常被称为extended sql trace,通常用于诊断确定的单个SQL、存储过程或会话的性能问题,具有如下的几个优点:

可以得到SQL执行时实际的执行计划。

可以得到SQL执行时所花时间的具体分布,CPU消耗了多长时间,多块读消耗了多长时间等等。

可以得到SQL执行时的各种与性能相关的统计数据,逻辑读、物理读、fetch次数、parse次数等等。

不仅能够用于性能测试,同时能够用于诊断正在执行的SQL或存储过程的性能。

有很多的工具用于格式化生成的trace文件,除了Oracle自带的TKPROF、Metalink Note 224270.1 Trace Analyzer,以及第三方的免费工具如orasrp,《Troubleshooting Oracle Performance》作者开发的TVD$XTAT,甚至还有商业化的软件Hotsos Profiler等。

不过前段时间在用10046事件诊断一个性能问题的时候,却让生成的结果误导了。后来仔细检查发现,在会话开启Oracle sql trace的情况下,SQL语句会重新解析,导致开启sql trace之后与开启之前相比,执行计划可能发生了变化,导致sql trace的结果不能真实地反映会话执行SQL的情况,在分析时容易发生偏差。

下面是一个测试:

测试的环境是Oracle 10.2.0.1 for Windows,不过前面提到的案例,是发生在Oracle 9i下的,所以9i和10g都有这个问题,而11g目前还没有测试过,有兴趣的朋友可以在11g上进行测试。

首先创建一个sql文件,内容为:

select/*+testsql*/sum(value)fromt1whereflag=:v_flag;

创建一个列上数据有倾斜的表

SQL>createtablet1(valuenumber,flagnumber,padvarchar2(2000));

表已创建。

SQL>insertintot1selectrownum,mod(rownum,2000),lpad('x',1000,'x')fromdba_objects;

已创建49796行。

SQL>commit;

提交完成。

SQL>insertintot1selectrownum,3000,lpad('x',1000,'x')fromdba_objectswhererownum<=10000;

已创建10000行。

SQL>commit;

提交完成。

SQL>createindext1_idxont1(flag);

索引已创建。

SQL>execdbms_stats.gather_table_stats(ownname=>user,tabname=>'T1',cascade=>true,method_opt=>'forallindexedcolumns');

PL/SQL 过程已成功完成。

SQL>selectcolumn_name,num_distinct,num_bucketsfromuser_tab_columnswheretable_name='T1'; 
COLUMN_NAMENUM_DISTINCTNUM_BUCKETS 
----------------------------------------------------- 
VALUE 
FLAG203075 
PAD 
select/*+testsql*/sum(value)fromt1whereflag=:v_flag;

创建一个列上数据有倾斜的表:

SQL>createtablet1(valuenumber,flagnumber,padvarchar2(2000));

表已创建。

SQL>insertintot1selectrownum,mod(rownum,2000),lpad('x',1000,'x')fromdba_objects;

已创建49796行。

SQL>commit;

提交完成。

SQL>insertintot1selectrownum,3000,lpad('x',1000,'x')fromdba_objectswhererownum<=10000;

已创建10000行。

SQL>commit;

提交完成。

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11146.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。