用T-SQL语句建立跟踪来帮助我们监测晚间Job运行情况

本文介绍了一种使用T-SQL语句启动SQL Server跟踪的方法,适用于通过设置Job来记录SQL Server执行的所有SQL语句,有助于查找错误发生时的真实SQL数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目中有很多的Job设在凌晨执行,如果发生错误我们很难查找,特别是很难得到错误发生时的真实Sql数据,如果我们能够在Job启动时SqlServer运行的所有Sql语句记录下来的话,对我们的查错工作带来很大的方便,下边的文章为我们提供来方法:

一般我们会用事件探查器来跟踪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:/MyFolder/MyTrace. 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
 
exec @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
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, 10, 0, 7, N'SQL Profiler'
set @intfilter = 100
exec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter
 
set @intfilter = 1
exec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter
 
exec sp_trace_setfilter @TraceID, 35, 1, 6, N'pubs'
 
 
-- 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
 
finish:
go
 
 
 
二、       生成跟踪脚本的最简式
事件探查器建立跟踪, 并设置好各种选项, 完成后运行跟踪
然后生成脚本:
   事件探查器--文件--导出跟踪定义的文件--选择合适的版本.
 
这样就会生成一个跟踪的脚本, 打开生成的脚本, 修改里面的:
exec @rc = sp_trace_create
部分, 设置跟踪结果的保存文件(用语句跟踪的时候, 跟踪结果只能保存到文件)
 
 
然后, 在需要跟踪的时候, 运行这个脚本来启动跟踪
 
启动跟踪后, 跟踪自动进行, 所以你可以关闭查询分析器做其他事情去了.
 
 
三、       已知的问题
1.    跟踪记录不是实时写入跟踪文件的, 因此, 可能会到你停止跟踪的时候, 跟踪信息才写入跟踪文件
2.    查看当前已经进行的跟踪可以用(关于结果集的解释, 请看联机帮助):
SELECT * FROM ::fn_trace_getinfo(0)
 
3.    停止某个跟踪, 可以在sp_trace_create 语句中设置自动停止时间, 也可以手动停止跟踪, 用下面的语句:
EXEC sp_trace_setstatus
    @traceid = 1 ,   -- 跟踪的id
    @status = 0      -- 停止, 这样以后还可能指定此项为来启用
EXEC sp_trace_setstatus
    @traceid = 1 ,
    @status = 2      -- 关闭, 彻底释放
 
 所以只要在我们的Job启动时,同时启动跟踪Job,我们就会得到Job运行时SqlServer执行的所有Sql数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值