博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用DBMS_SUPPORT包
阅读量:7043 次
发布时间:2019-06-28

本文共 2136 字,大约阅读时间需要 7 分钟。

DBMS_SUPPORT包从Oracle7.2引入,主要功能用以提供更完整的用户session跟踪信息,这个包可以通过运行 dbmssupp.sql 和 prvtsupp.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

转载地址:http://vmqal.baihongyu.com/

你可能感兴趣的文章
头条面试题
查看>>
Vue实现一个图片懒加载插件
查看>>
Java开发人员必备Linux命令
查看>>
记一次中台数据传输同步Elasticsearch失败的车祸现场
查看>>
141. Linked List Cycle
查看>>
外部资料集合
查看>>
如何高效读写百万级的Excel?
查看>>
初入门,在vue中使用axios
查看>>
"Sed" 高级功能:我这小脑瓜都快绕晕了
查看>>
另一个go命令行参数处理器 - cmdr
查看>>
WebKit 浏览器内幕之 浏览器特性/网页渲染过程
查看>>
一个只需要一行代码即可调出的 Progress,高度定制
查看>>
程序人生阶段性随笔
查看>>
《锦绣中华》发布会之苏州金鹰国际广场站
查看>>
Qtum量子链周报(4月22日-4月28日)
查看>>
【转】完全理解 redux(从零实现一个 redux)
查看>>
遇到的柯里化函数使用场景记录
查看>>
tomcat调优
查看>>
个人不足点总结
查看>>
BLS 签名和基于 BLS 签名的门限签名
查看>>