用10046 跟踪实例

用10046 trace工具开始跟踪:

SQL> alter session set events '10046 trace name context forever,level 12';

Session altered.

执行一些操作:

执行数据库包:

exec pkgtest('abc');

查询

SQL> select count(*) from dba_tables;

  COUNT(*)
----------
      1863

SQL> select count(*) from dba_objects;

  COUNT(*)
----------
     53193

SQL>  select count(*) from test;

  COUNT(*)
----------
   1275744

执行包完毕后结束跟踪:


alter session set events '10046 trace name context off';

找出trc文件
SQL> oradebug setmypid
Statement processed.
SQL> oradebug tracefile_name
/apps/oracle/product/10.2.0/db_1/admin/gcomsdb/udump/gcomsdb_ora_2171.trc

--这种方法适用于sys用户

格式化后进行分析,如下:


SQL> ho
[oracle@dbserver1 ~]$ tkprof /apps/oracle/product/10.2.0/db_1/admin/gcomsdb/udump/gcomsdb_ora_2171.trc

10046test.txt
[oracle@dbserver1 ~]$ tkprof /apps/oracle/product/10.2.0/db_1/admin/gcomsdb/udump/gcomsdb_ora_2171.trc

10046test1.txt sort=prsela,exeela,fchela

[oracle@dbserver1 ~]$ tkprof /apps/oracle/product/10.2.0/db_1/admin/gcomsdb/udump/gcomsdb_ora_9350.trc

test10046.txt sys=no sort=prsela,exeela,fchela


这里列了三种,最后一个响应时间从大到小排序所有语句,然后分析test10046.txt的文件,即可得到:

 1.该过程包和查询总共执行了多少SQL语句,具体内容是什么,分别开销了多少时长;

  2.哪些是开销时长最长的语句。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值