• 博客访问: 7792387
  • 博文数量: 798
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-16 22:27
  • 认证徽章:
个人简介

Oracle ACE 总监,OCM联盟(ocmu.org)创始人,恩墨学院(enmoedu.com)创始人,ITPUB Oracle专题深入讨论版版主,资深Oracle数据库专家,北京大学理学硕士,获Oracle OCM 10g 11g认证,ACOUG核心成员,DATAGURU专家团成员,Blogger。Good luck.

文章分类

全部博文(798)

文章存档

2013年(1)

2012年(18)

2011年(156)

2010年(302)

2009年(309)

2008年(7)

2007年(5)

分类: Linux操作系统

2009-10-06 22:06:26

提到SQL优化,不能不提AUTOTRACE的强大功能。使用起来非常便捷,不过在是使用之前,需要做一些配置的工作。简要的描述一下这个过程,供没有使用过的朋友参考。

1.使用sys用户执行plustrce脚本
sys@ora10g> @?/sqlplus/admin/plustrce
sys@ora10g> drop role plustrace;
drop role plustrace
          *
ERROR at line 1:
ORA-01919: role 'PLUSTRACE' does not exist


sys@ora10g> create role plustrace;

Role created.

sys@ora10g>
sys@ora10g> grant select on v_$sesstat to plustrace;

Grant succeeded.

sys@ora10g> grant select on v_$statname to plustrace;

Grant succeeded.

sys@ora10g> grant select on v_$mystat to plustrace;

Grant succeeded.

sys@ora10g> grant plustrace to dba with admin option;

Grant succeeded.

sys@ora10g>
sys@ora10g> set echo off

2.将plustrace授权给public用户,以便保证所有用户都有权使用autotrace功能
sys@ora10g> grant plustrace to public;

Grant succeeded.

3.连接到具体的用户中,这里是sec用户
sys@ora10g> conn sec/sec
Connected.

4.使用“set autotrace”查看autotrace的命令提示
sec@ora10g> set autotrace
Usage: SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]

5.这里演示一种设置方法
sec@ora10g> set autotrace traceonly
sec@ora10g> select * from cat;

20 rows selected.


Execution Plan
----------------------------------------------------------
Plan hash value: 3442307057

--------------------------------------------------------------------------------
| Id  | Operation             | Name   | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT      |        |   646 | 47804 |    33   (4)| 00:00:01 |
|*  1 |  FILTER               |        |       |       |            |          |
|*  2 |   TABLE ACCESS FULL   | OBJ$   |  1324 | 97976 |    33   (4)| 00:00:01 |
|*  3 |   TABLE ACCESS CLUSTER| TAB$   |     1 |    12 |     2   (0)| 00:00:01 |
|*  4 |    INDEX UNIQUE SCAN  | I_OBJ# |     1 |       |     1   (0)| 00:00:01 |
--------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

   1 - filter("O"."TYPE#"=4 OR "O"."TYPE#"=5 OR "O"."TYPE#"=6 OR
              "O"."TYPE#"=2 AND  NOT EXISTS (SELECT /*+ */ 0 FROM "SYS"."TAB$" "T"
              WHERE "T"."OBJ#"=:B1 AND (BITAND("T"."PROPERTY",512)=512 OR
              BITAND("T"."PROPERTY",8192)=8192)))
   2 - filter("O"."OWNER#"=USERENV('SCHEMAID') AND "O"."LINKNAME" IS
              NULL)
   3 - filter(BITAND("T"."PROPERTY",512)=512 OR
              BITAND("T"."PROPERTY",8192)=8192)
   4 - access("T"."OBJ#"=:B1)


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
        207  consistent gets
          0  physical reads
          0  redo size
        876  bytes sent via SQL*Net to client
        492  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
         20  rows processed


更多的有趣内容,请您慢慢挖掘。

-- The End --
阅读(1604) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~

strawbingo2010-04-19 11:23:12

谢谢,哈:victory:

secooler2010-04-14 14:34:09

原帖由strawbingo于2010-04-14 11:09:40发表 我PL/SQL中view对象 v$sesstat 显示的却是 create or replace view sys.v_$sesstat as select "S
不奇怪,这是Oracle为了权限控制做的一个设计。 请参考这篇文章《【视图】深入探究 V$PARAMETER的底层查询内幕》http://space.itpub.net/519536/viewspace-630542 希望对您有帮助。 secooler

strawbingo2010-04-14 11:09:40

我PL/SQL中view对象 v$sesstat 显示的却是 create or replace view sys.v_$sesstat as select "SID","STATISTIC#","VALUE" from v$sesstat。 很奇怪啊!!

评论热议
请登录后评论。

登录 注册