数据库专家答疑目录

  |  手机版

收藏网站

投稿QQ:1745232315

IT专家网,汇聚专业声音 解析IT潮流 IT专家网,汇聚专业声音 解析IT潮流

网络

专家视点在现场环球瞭望
IT专家网 > 数据库子站 > 数据库专家答疑目录

捕捉一个SQL Server会话的所有语句

作者:唐小若出处:IT专家网2009-03-20 09:55

  首先需要做的是创建两个存储过程,在这个技巧中,我在自己的主数据库上创建它们。它们允许你创建一个服务器端的跟踪,也允许你关掉一个服务器端的跟踪。要了解更多关于服务器端跟踪的信息,请参考前面的技巧“使用一个服务器端得跟踪进行SQL Server 性能统计”。

  开始跟踪

  第一个存储过程显示如下,它启动了服务器端的跟踪,但是也排除了你想捕捉的特定会话的SPID。它将创建一个文件名,如“TraceMySession_52_d20090317120912.trc”,以便该跟踪会话是唯一的。默认情况下,它保存在服务器的"C:"盘下,因此你可以把它更改到另一个不同的目录下。建立这个脚本也是为了创建一个5MB的文件然后回滚到另外的文件中。你可以再次检验上面提到的技巧得到更多关于这些设置的信息。

  我们正在做的另一件事是只捕捉SQL:BatchCompleted事件。用这种方法这个跟踪文件不会变得非常大。捕捉的三个数据字段是TextData,StartTime和SPID。

  要创建这个存储过程,复制下面的代码并且执行它。正如我所说的,我在主数据库中创建这个程序,但是你也可以在不同的数据库中创建它。

  

     CREATE PROCEDURE [dbo].[spTraceMySessionStart] @spid INT

  AS

  -- Create a Queue

  DECLARE @rc INT

  DECLARE @TraceID INT

  DECLARE @maxfilesize bigint

  SET @maxfilesize = 5

  DECLARE @filename NVARCHAR(245)

  SET @filename = 'C:\TraceMySession_'

  + CONVERT(NVARCHAR(10),@spid)

  + '_d'

  + REPLACE(CONVERT(VARCHAR, GETDATE(),111),'/','')

  + REPLACE(CONVERT(VARCHAR, GETDATE(),108),':','')

  EXEC @rc = sp_trace_create @TraceID output, 2, @filename, @maxfilesize, NULL

  IF (@rc != 0) GOTO error

  -- Set the events

  DECLARE @on bit

  SET @on = 1

  EXEC sp_trace_setevent @TraceID, 12, 1, @on

  EXEC sp_trace_setevent @TraceID, 12, 12, @on

  EXEC sp_trace_setevent @TraceID, 12, 14, @on

  -- Set the Filters

  DECLARE @intfilter INT

  DECLARE @bigintfilter bigint

  EXEC sp_trace_setfilter @TraceID, 12, 1, 0, @spid

  -- Set the trace status to start

  EXEC sp_trace_setstatus @TraceID, 1

  -- display trace id for future references

  SELECT TraceID=@TraceID

  GOTO finish

  error:

  SELECT ErrorCode=@rc

相关文章

关键词: 评论

责任编辑:包春林

专题推荐

原创文章

微博互动

白皮书

网警备案