SQL Trace主要是对数据库进行SQL监测,可以随时监测和调整作用于数据的应用程序。比如ERP系统它的应用界面很多,涉及的底层操作也很多,如果想知道在某个界面的操作在底层数据库执行了哪些SQL语句,就需要开启Trace功能记录下这些SQL操作,方便开发人员了解上层应用程序对数据库做了哪些动作。本篇通过简单实例演示如何使用TKPROF阅读Oracle Trace文件。

1. 开启Trace功能

有些应用程序本身可以提供开启Trace的功能。比如Oracle的ERP在应用程序界面的菜单栏都会有Trace功能,如下图:

TKPROF阅读Oracle Trace

PL/SQL的菜单中也有相同设置:

TKPROF阅读Oracle Trace

当然也可以在SQLPLUS中执行下面命令来开启Trace:

alter session set sql_trace = true; /*开启*/
alter session set sql_trace = false; /*关闭*/

2. 记录SQL到Trace文件

通过SQLPLUS登录数据库,开启Trace功能,执行一个SQL语句,关闭Trace:

TKPROF阅读Oracle Trace

3. 浏览Trace文件

打开Trace文件目录: 
cd /ora10g/admin/otdrdb/udump

按日期显示,出现在顶端的文件即为刚刚生成的Trace文件: 
ls –t |more TKPROF阅读Oracle Trace

先看一下未经过处理的Trace文件,其内容格式不方便阅读: 
more otdrdb_ora_30597.trc

TKPROF阅读Oracle Trace

用tkprof 对otdrdb_ora_30597.trc进行一下处理: 
tkprof otdrdb_ora_30597.trc 
输入output文件名称,例如otdrdb_ora_30597.txt TKPROF阅读Oracle Trace

再来看一下处理后otdrdb_ora_30597.txt文件的内容: 
TKPROF阅读Oracle Trace

之前执行的select count(*) from users语句就会在Trace文件中体现出来,并且相应的一些执行参数也会体现出来。 这样就可以通过这个方式随时监视应用程序对数据库的操作了。

更多TKPROF内容可参考http://download-west.oracle.com/docs/cd/B10501_01/server.920/a96533/sqltrace.htm#1018






本文转自Gnie博客园博客,原文链接:http://www.cnblogs.com/gnielee/archive/2009/08/19/1549725.html,如需转载请自行联系原作者

相关文章:

  • 2021-08-10
  • 2021-08-24
  • 2022-12-23
  • 2022-12-23
  • 2021-11-28
  • 2021-10-06
  • 2022-12-23
猜你喜欢
  • 2021-09-26
  • 2021-12-22
  • 2021-11-22
  • 2021-09-26
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案