如何启用sqlplus的AutoTrace功能

通过以下方法可以把Autotrace的权限授予Everyone如
果你需要限制Autotrace权限,可以把对public的授权改为对特定user的授权。





D:\oracle\ora92>sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - Production on 星期二 6月 3 15:16:03 2003

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

SQL> connect sys as sysdba
请输入口令:
已连接。
SQL> @?\rdbms\admin\utlxplan

表已创建。

SQL> create public synonym plan_table for plan_table;

同义词已创建。

SQL> grant all on plan_table to public ;

授权成功。


SQL> @?\sqlplus\admin\plustrce
SQL>
SQL> drop role plustrace;
drop role plustrace
*
ERROR 位于第 1 行:
ORA-01919: 角色'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_$session to plustrace;

授权成功。

SQL> grant plustrace to dba with admin option;

授权成功。

SQL>
SQL> set echo off





DBA用户首先被授予了plustrace角色,然后我们可以把plustrace授予public

这样所有用户都将拥有plustrace角色的权限.





SQL> grant plustrace to public ;

授权成功。




然后我们就可以使用AutoTrace的功能了.





SQL> connect eqsp/eqsp
已连接。
SQL> set autotrace on
SQL> set timing on
SQL>







关于Autotrace几个常用选项的说明:

SET AUTOTRACE OFF ---------------- 不生成AUTOTRACE 报告,这是缺省模式
SET AUTOTRACE ON EXPLAIN ------ AUTOTRACE只显示优化器执行路径报告
SET AUTOTRACE ON STATISTICS -- 只显示执行统计信息
SET AUTOTRACE ON ----------------- 包含执行计划和统计信息
SET AUTOTRACE TRACEONLY ------ 同set autotrace on,但是不显示查询输出



SQL> set autotrace traceonly
SQL> select table_name from user_tables;

已选择98行。

已用时间: 00: 00: 00.04

Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE
1 0 NESTED LOOPS
2 1 NESTED LOOPS (OUTER)
3 2 NESTED LOOPS (OUTER)
4 3 NESTED LOOPS (OUTER)
5 4 NESTED LOOPS (OUTER)
6 5 NESTED LOOPS
7 6 TABLE ACCESS (BY INDEX ROWID) OF 'OBJ$'
8 7 INDEX (RANGE SCAN) OF 'I_OBJ2' (UNIQUE)
9 6 TABLE ACCESS (CLUSTER) OF 'TAB$'
10 9 INDEX (UNIQUE SCAN) OF 'I_OBJ#' (NON-UNIQUE)
11 5 TABLE ACCESS (BY INDEX ROWID) OF 'OBJ$'
12 11 INDEX (UNIQUE SCAN) OF 'I_OBJ1' (UNIQUE)
13 4 INDEX (UNIQUE SCAN) OF 'I_OBJ1' (UNIQUE)
14 3 TABLE ACCESS (CLUSTER) OF 'USER$'
15 14 INDEX (UNIQUE SCAN) OF 'I_USER#' (NON-UNIQUE)
16 2 TABLE ACCESS (CLUSTER) OF 'SEG$'
17 16 INDEX (UNIQUE SCAN) OF 'I_FILE#_BLOCK#' (NON-UNIQUE)
18 1 TABLE ACCESS (CLUSTER) OF 'TS$'
19 18 INDEX (UNIQUE SCAN) OF 'I_TS#' (NON-UNIQUE)



Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
1389 consistent gets
0 physical reads
0 redo size
2528 bytes sent via SQL*Net to client
569 bytes received via SQL*Net from client
8 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
98 rows processed

SQL>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL*Plus是Oracle提供的一个基于文本的命令行工具,用于连接、管理和执行SQL语句和PL/SQL代码。下面是一些SQL*Plus命令的详细说明: 1. CONNECT:用于连接到一个Oracle数据库实例。可以指定用户名、密码和数据库名称。 2. SELECT:用于从数据库检索数据。可以使用WHERE子句对数据进行筛选,并使用ORDER BY子句对结果进行排序。 3. INSERT:用于向数据库插入新的行。需要指定表名和要插入的值。 4. UPDATE:用于更新数据库的行。可以使用WHERE子句对要更新的行进行筛选,并指定要更新的字段和新值。 5. DELETE:用于删除数据库的行。同样可以使用WHERE子句对要删除的行进行筛选。 6. COMMIT:用于提交事务。将之前的SQL操作永久保存到数据库。 7. ROLLBACK:用于回滚事务。取消之前的SQL操作,恢复到上一个提交点。 8. CREATE TABLE:用于创建新的数据库表。需要指定表名、字段名和数据类型。 9. ALTER TABLE:用于修改数据库表的结构。可以添加、修改或删除表的字段。 10. DROP TABLE:用于删除数据库表。 11. DESC:用于显示数据库表的结构,包括字段名、数据类型和约束。 12. SET AUTOTRACE:用于启用或禁用执行查询计划和统计信息的跟踪。 13. SET PAGESIZE:用于设置输出结果的页面大小。 14. SPOOL:用于将结果输出保存到一个文件。 15. START:用于执行一个包含SQL*Plus命令和脚本的文件。 16. EXIT或QUIT:用于退出SQL*Plus。 这些命令只是SQL*Plus的一部分功能,它还提供了很多其他命令和选项,可以用于自定义和优化数据库查询和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值