如何用T-SQL语句来建立启动跟踪

日期: 2008-06-17 来源:TechTarget中国

  一般我们会用事件探查器来跟踪SQL Server的运行情况,有时我们也需要定时进行一些跟踪,以检查SQL Server在某个时间段内的运行状况,由于事件探查器不支持调度,因此,应该寻找一种方法,适合我们通过设置JOB来启动跟踪,本文介绍的用T-SQL语句来启用跟踪就适合这种需求。


  一、用脚本启动并设置跟踪的示例


  通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助








/****************************************************/ /* created by: SQL Profiler */ /* Date: 2004/06/19 16:50:05 */ /****************************************************/ — create a Queue declare @rc int declare @TraceID int declare @maxfilesize bigint set @maxfilesize = 5 — Please replace the text insertFileNameHere, with an appropriate — filename prefixed by a path, e.g., c:MyFolderMyTrace. The .trc extension — will be appended to the filename automatically. If you are writing from — remote server to local drive, please use UNC path and make sure server has — write access to your network share &#101xec @rc = sp_trace_create @TraceID output, 0, N’c:test’, @maxfilesize, NULL if (@rc != 0) goto error — Client side File and Table cannot be scripted — Writing to a table is not supported through the SP’s — Set the events declare @on bit set @on = 1 &#101xec sp_trace_setevent @TraceID, 12, 1, @on &#101xec sp_trace_setevent @TraceID, 12, 12, @on &#101xec sp_trace_setevent @TraceID, 12, 14, @on — Set the Filters declare @intfilter int declare @bigintfilter bigint &#101xec sp_trace_setfilter @TraceID, 10, 0, 7, N’SQL Profiler’ set @intfilter = 100 &#101xec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter set @intfilter = 1 &#101xec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter &#101xec sp_trace_setfilter @TraceID, 35, 1, 6, N’pubs’ — Set the trace status to start &#101xec sp_trace_setstatus @TraceID, 1 — display trace id for future references select TraceID=@TraceID goto finish error: select ErrorCode=@rc finish: go
 


  二、生成跟踪脚本的最简式


  事件探查器建立跟踪, 并设置好各种选项, 完成后运行跟踪


  然后生成脚本:


  事件探查器–文件–导出跟踪定义的文件–选择合适的版本.


  这样就会生成一个跟踪的脚本, 打开生成的脚本, 修改里面的:


  &#101xec @rc = sp_trace_create


  部分, 设置跟踪结果的保存文件(用语句跟踪的时候, 跟踪结果只能保存到文件)


  然后, 在需要跟踪的时候, 运行这个脚本来启动跟踪


  启动跟踪后, 跟踪自动进行, 所以你可以关闭查询分析器做其他事情去了.


  三、已知的问题


  1. 跟踪记录不是实时写入跟踪文件的, 因此, 可能会到你停止跟踪的时候, 跟踪信息才写入跟踪文件


  2. 查看当前已经进行的跟踪可以用(关于结果集的解释, 请看联机帮助):







  select * FROM ::fn_trace_getinfo(0)


  3. 停止某个跟踪, 可以在sp_trace_create 语句中设置自动停止时间, 也可以手动停止跟踪, 用下面的语句: 







&#101xec sp_trace_setstatus @traceid = 1 , — 跟踪的id @status = 0 — 停止, 这样以后还可能指定此项为来启用 &#101xec sp_trace_setstatus @traceid = 1 , @status = 2 — 关闭, 彻底释放

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

相关推荐