Oracle SQL trace的正确使用以及需注意的问题

数据库 Oracle
以下的文章主要是介绍如何正确使用Oracle SQL trace,以及在实际操作中都有哪些值得我们注意的问题,以下就是正文的主要内容的描述。

今天主要向大家介绍的是如何正确的使用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文件,内容为:

  1. select /*+ testsql */ sum(value) from t1 where flag=:v_flag;  

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

  1. SQL> create table t1 (value number ,flag number,pad varchar2(2000));  

表已创建。

  1. SQL> insert into t1 select rownum,mod(rownum,2000),lpad('x',1000,'x') from dba_objects;  

已创建49796行。

  1. SQL> commit;  

提交完成。

  1. SQL> insert into t1 select rownum,3000,lpad('x',1000,'x') from dba_objects where rownum<=10000;  

已创建10000行。

  1. SQL> commit;  

提交完成。

  1. SQL> create index t1_idx on t1(flag);  

索引已创建。

  1. SQL> exec dbms_stats.gather_table_stats(ownname=>user,tabname=>'T1',cascade=>true,method_opt=>'for all indexed columns');  

PL/SQL 过程已成功完成。

  1. SQL> select column_name,num_distinct,num_buckets from user_tab_columns where table_name='T1';   
  2. COLUMN_NAME NUM_DISTINCT NUM_BUCKETS   
  3. ------------------------------ ------------ -----------   
  4. VALUE   
  5. FLAG 2030 75   
  6. PAD   
  7. select /*+ testsql */ sum(value) from t1 where flag=:v_flag;  

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

  1. SQL> create table t1 (value number ,flag number,pad varchar2(2000));  

表已创建。

  1. SQL> insert into t1 select rownum,mod(rownum,2000),lpad('x',1000,'x') from dba_objects;  

已创建49796行。

  1. SQL> commit;  

提交完成。

 

  1. SQL> insert into t1 select rownum,3000,lpad('x',1000,'x') from dba_objects where rownum<=10000; 

已创建10000行。

  1. SQL> commit;  

提交完成。上述的相关内容就是对使用Oracle SQL trace时需要注意的问题的描述,希望会给你带来一些帮助在此方面。

【编辑推荐】

  1. 实现Oracle传输表空间的实际功能解析
  2. Oracle rownum用法的归纳
  3. Oracle存储过程定时执行2种方法
  4. Oracle 10g中的hints调整机制详解
  5. 提高Oracle SQL的执行效率的3个方案
责任编辑:佚名 来源: 博客园
相关推荐

2010-05-06 16:02:42

Oracle SQL

2010-09-01 09:03:25

DB2临时表

2015-04-16 16:42:11

私有云云部署

2011-05-05 14:27:17

喷码机耗材

2010-04-23 09:51:12

Oracle工具

2013-05-08 09:14:35

网络维护网吧网管

2017-05-25 11:49:30

Android网络请求OkHttp

2011-07-27 09:57:24

SQL TraceOracle

2023-09-28 09:07:54

注解失效场景

2011-09-14 15:23:00

Android 2.2

2011-07-11 13:16:19

SQL TraceSQL Profile

2009-06-11 16:42:51

家庭组网网络设备安装

2013-10-21 14:39:40

数据

2011-07-01 15:27:29

网站优化

2010-05-20 18:15:31

2010-07-19 16:55:51

Telnet命令

2010-04-07 14:59:02

校园服务器

2011-07-03 23:40:54

友情链接

2013-04-07 11:31:05

云计算合同

2013-04-15 09:48:40

AndroidAVD错误处理方法
点赞
收藏

51CTO技术栈公众号