如何将SQL Profiler Trace读入到SQL的表中?

SQL Profiler是个很强大的工具, 分析原理的时候按顺序读读也还好的, 可是如果要分析一些比较复杂的情况, 就需要比较更多的一点东西了.

在这里介绍一种方法, 可以将像操作SQL的table一样的操作Profiler Trace, 这样就可以进行使用select这样的操作来查看自己感兴趣的信息了.

 

完成这样功能的方法是使用一个叫做fn_trace_gettable的内建函数.

select * 
from fn_trace_gettable('c:\MyTraceFile.trc', default)

第一个参数很显然是磁盘上的profiler trace的路径.

第二个参数是应该被读取的文件的数量, default的值是-1, 意味着所有文件均要读取.

 

尽管你可以使用这个函数每次读取trace文件, 还有一个更好的方法, 那就是将文件中的数据导入到一张table中, 然后对表进行查询, 这样比每次都去读取文件要快许多.

方法如下:

select IDENTITY(BIGINT, 1, 1) AS RowNumber, * 
into MyTraceTable
from fn_trace_gettable('D:\MyProfilerTrace.trc', default)
where 1 = 0  --just create the table without any data

 

一旦你创建好了表定义, 下一步就是把数据插入到表中.

insert into MyTraceTable
select * 
from fn_trace_gettable('D:\MyProfilerTrace.trc', default)

 

额外添加

===========

读入表后, 可以尝试运行下面的语句来选择运行时间最长的语句或存储过程.

select top 50 T.RowNumber, TE.name,T.duration DurationMicroSeconds,T.TextData 
    from MyTraceTable T
        join sys.trace_events TE ON T.EventClass = TE.trace_event_id
where eventclass <> 15
order by T.duration
desc

 

在这里你可以看到行号. 用SQL profiler打开trace文件, 就可以定位到问题语句的上下文了.

 

参考资料:

Reading a SQL Profiler Trace file

http://sql2005ted.blogspot.com/2009/06/reading-sql-profiler-trace-file.html

 

 

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值