Decode360's Blog

业精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

  BlogJava :: 首页 :: 新随笔 :: 联系 ::  :: 管理 ::
  397 随笔 :: 33 文章 :: 29 评论 :: 0 Trackbacks
使用DBMS_SUPPORT包
 
    原本是想找个简单的放来,来确定当前session的SID号的,在网上就发现了这个Package,感觉还不错,不但可以以最简单的方式得到SID,而且还可以对当前session进行Trace,包小但是很实用。唯一的缺点是这个包需要自己进行编译才可以,比较麻烦。下面转篇文章简单介绍一下。
------------------------------------------------------------------------------------
 
使用DBMS_SUPPORT包
 
作者: eygle | English Version 【转载时请以超链接形式标明文章 和作者信息及 本声明
链接:

 

DBMS_SUPPORT包从Oracle7.2引入,主要功能用以提供更完整的用户session跟踪信息

这个包可以通过运行 dbmssupp.sqlprvtsupp.plb 两个脚本来创建.

该脚本位于$ORACLE_HOME/rdbms/admin目录下

以下版本中都包含这些文件:

8.0.6, 8.1.7, 9.0.1, 9.2.0 and above

1.创建DBMS_SUPPORT Package

SQL> @?/rdbms/admin/dbmssupp.sql

Package created.

Package body created.

SQL> @?/rdbms/admin/prvtsupp.plb

Package body created.

2.主要函数及过程

SQL> desc dbms_support

FUNCTION MYSID RETURNS NUMBER

FUNCTION PACKAGE_VERSION RETURNS VARCHAR2

PROCEDURE START_TRACE
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
WAITS                          BOOLEAN                 IN     DEFAULT
BINDS                          BOOLEAN                 IN     DEFAULT

PROCEDURE START_TRACE_IN_SESSION
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
SID                            NUMBER                  IN
SERIAL                         NUMBER                  IN
WAITS                          BOOLEAN                 IN     DEFAULT
BINDS                          BOOLEAN                 IN     DEFAULT

PROCEDURE STOP_TRACE

PROCEDURE STOP_TRACE_IN_SESSION
Argument Name                  Type                    In/Out Default?
------------------------------ ----------------------- ------ --------
SID                            NUMBER                  IN
SERIAL                         NUMBER                  IN

3.简单用法

SQL> SELECT DBMS_SUPPORT.MYSID from DUAL;

MYSID
----------
8

SQL> select dbms_support.PACKAGE_VERSION from dual;

PACKAGE_VERSION
--------------------------------------------------------------------------------
DBMS_SUPPORT Version 1.0 (17-Aug-1998) - Requires Oracle 7.2 - 8.0.5

 

4.进程跟踪(跟踪当前session及其他session)

SQL> exec dbms_support.start_trace

PL/SQL procedure successfully completed.

SQL> select count(*) from dba_users;

COUNT(*)
----------
34

SQL> exec dbms_support.stop_trace;

PL/SQL procedure successfully completed.

SQL> select sid,serial#,username from v$session
2 /

SID        SERIAL#    USERNAME
---------- ---------- ------------------------------
1          1
2          1
3          1
4          1
5          1
6          1
7          1
8          764        SYS

8 rows selected.

SQL> exec dbms_support.start_trace_in_session(4,1);

PL/SQL procedure successfully completed.

SQL> exec dbms_support.stop_trace_in_session(4,1);

PL/SQL procedure successfully completed.

 

5.Trace文件

以上跟踪生成的Trace文件可以在udump目录下找到.

SQL> show parameter user_dump

NAME                 TYPE        VALUE
-------------------- ----------- ---------------------------------
user_dump_dest       string      /opt/oracle/admin/hsjf/udump

 

 
 
posted on 2009-03-06 22:23 decode360 阅读(112) 评论(0)  编辑  收藏 所属分类: 06.PLSQL

只有注册用户登录后才能发表评论。


网站导航: