(转)Autotrace工具使用——小工具,大用场 - newmanzhang

时间:2024-02-23 18:18:30

(转)Autotrace工具使用——小工具,大用场

监控SQL语句,获取执行计划和执行成本,是每个Oracle开发人员与DBA所必须具备的能力之一。

当Oracle彻底进入CBO时代,我们面对一种全新的局面。一方面,基于数据统计量的CBO优化器,让SQL语句执行计划生成更加科学、更加有效。但是另一方面,优化器和优化模式也变得越来越复杂。我们对于一个SQL操作的执行计划关注度和不确定程度同时在提升。

在这样的情况下,Oracle提供了一系列的观察SQL执行计划的工具,其中Autotrace工具是最简单和常用的工具。

简单的说,Autotrace工具具有对SQL语句执行计划进行分析输出,以及评估执行使用资源。下面,我们对Autotrace工具从安装、使用到结果分析进行简单的介绍。

Autotrace安装

首先,有一点需要说明:Autorace工具是在Oracle提供的Sqlplus窗口上使用。在如pl/sql developer之类的开发工具上是不能使用的。sqlplus虽然使用简单,但是存在界面交互性差的特点。所以如果在Windows平台上,可以在sqlplusw中使用autotrace。不过很遗憾的是,Oracle11g中,sqlplusw这个鸡肋工具也已经不存在了。

还有一点建议的是,Autotrace是一个很安全的调试工具。最好可以设置给所有Oracle可以访问到(赋给public用户)。但是,安装的过程中因为存在赋权限相关的内容,最好使用sys用户登录。

安装Autotrace工具,共分为两个步骤:

步骤一、创建plan_table数据表。Plan_table是Oracle中一个很常用的数据表。它主要为各种工具提供装载生成sql执行计划的空间。

//使用Windows环境下做演示;

SQL*Plus: Release 10.2.0.1.0 - Production on 星期日 1月 30 20:22:07 2011

Copyright (c) 1982, 2005, Oracle. All rights reserved.

SQL> conn / as sysdba;

已连接。

SQL> show user

USER 为 "SYS"

 

SQL> @?\rdbms\admin\utlxplan.sql

 

表已创建。

建立数据表:plan_table是通过脚本utlxplan.sql实现的。该脚本在${ORACLE_HOME}/rdbms/admin目录下(注意windows和Linux/Unix目录结构的差异)。

该端演示是使用sqlplusw进行的。其中?表示${ORACLE_HOME}目录,在sqlplus中可以使用?来进行代表。如果在其他工具下,比如PL/SQL Developer下,可以在command窗口下使用 @{脚本路径}\utlxplan.sql。该脚本只是一个create table plan_table命令,如果有兴趣可以单独打开该文件。

之后,通过公有同义词和授权方法,将plan_table使用权给所有用户。

SQL> create public synonym plan_table for plan_table;

SQL> grant all on plan_table to public;

授权成功。

步骤二、安装autotrace脚本

autotrace工具脚本执行。在sqlplusw窗口下执行:

SQL> @?\sqlplus\admin\plustrce.sql//注意是plustrce.sql,不是plustrace.sql,笔者当年困惑了好久。。。

SQL>

SQL> drop role plustrace;

角色已删除。

SQL> create role plustrace;

角色已创建。

SQL>

SQL> grant select on v_$sesstat to plustrace;

授权成功。

SQL> grant select on v_$statname to plustrace;

授权成功。

SQL> grant select on v_$mystat to plustrace;

授权成功。

SQL> grant plustrace to dba with admin option;

授权成功。

上面的脚本中,只有@?\sqlplus\admin\plustrce.sql是需要输入的内容,其他都是输入脚本的语句。

最后,如果希望所有的用户都能使用的autotrace工具,只要将plustrace角色赋给public就可以了。

SQL> grant plustrace to public;

授权成功。

设置结束后,我们已经完全安装好autotrace工具了。下面简单介绍一下,如果和使用autotrace工具。

 

使用autotrace

使用autorace是在sqlplus环境下,通过对autotrace的开启关闭来设置。下面是一个简单的例子。

SQL> conn scott/tiger@orcl

已连接。

SQL> set timing on;//设置其可以显示出所有sql语句的执行时间,非常实用!!

SQL> set autotrace on; //设置所有的内容。

SQL> select count(*) from emp;

 

 COUNT(*)

----------                  ………………………语句执行结果

       14

 

已用时间: 00: 00: 00.03

 

执行计划

----------------------------------------------------------

Plan hash value: 2937609675

 

-------------------------------------------------------------------

| Id | Operation       | Name  | Rows | Cost (%CPU)| Time    |

-------------------------------------------------------------------

|  0 | SELECT STATEMENT |       |    1 |    1  (0)| 00:00:01 |

|  1 | SORT AGGREGATE |       |    1 |           |         |

|  2 |  INDEX FULL SCAN| PK_EMP |   14 |    1  (0)| 00:00:01 |

-------------------------------------------------------------------

统计信息

----------------------------------------------------------

       219 recursive calls

         0 db block gets

        41 consistent gets

         1 physical reads

         0 redo size

       408 bytes sent via SQL*Net to client

       385 bytes received via SQL*Net from client

         2 SQL*Net roundtrips to/from client

         5 sorts (memory)

         0 sorts (disk)

         1 rows processed

 

SQL>

观察这个输出结果,我们可以看出结果分为下面几个部分:

 

1、输出结果:SQL语句的结果;

2、执行计划;

3、统计信息;

 

每个部分分别承担了不同的地位和作用。但是有一点需要注意,输出的执行计划和依据,都是根据统计量进行评估的结果。实际执行的成本常常与执行计划后面每个步骤的数值有差异。

 

对set autotrace命令,还存在一些变种,方便使用。

 

I       set autotrace on explain; 只显示出执行计划;

II      set autotrace on statistics; 只显示出统计量信息;

III      set autotrace traceonly; 不显示查询结果;

IIII      set autotrace traceonly explain; 只显示执行语句,并且不会执行语句。最适合进行大表操作的预估算;

 

 

最后,我们介绍一下统计量的各部分含义。

 

项目

含义

备注

recursive calls

递归调用SQL的个数;Oracle在执行这个SQL的时候,有时候会生成很多额外的SQL语句,这个就成为递归调用;

 

db block gets

逻辑读,从数据buffer cache中读取;进行current模式读取;

 

consistent gets

逻辑读,进行一致读模式读取;

 

physical reads

物理读成本;

 

redo size

产生重做日志大小

 

bytes sent via SQL*Net to client

利用sql*net传入到client的字节数;

 

bytes received via SQL*Net from client

利用sql*net传出client的字节数;

 

SQL*Net roundtrips to/from client

 

 

sorts (memory)

内存中排序空间使用;

 

sorts (disk)

物理存储中排序空间使用;

如果memory空间使用不足,是会使用disk的空间的;

rows processed

 

 

 

 

Autorace工具是我们经常使用的性能评测工具,能够帮助解决很多问题。与其相同地位的还有dbms_xplan包方法和set events跟踪事件文件。

转自:http://space.itpub.net/17203031/viewspace-686535