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

一、       用脚本启动并设置跟踪的示例<o:p></o:p>

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

/****************************************************/<o:p></o:p>

/* Created by: SQL Profiler                         */<o:p></o:p>

/* Date: 2004/06/19  16:50:05         */<o:p></o:p>

/****************************************************/<o:p></o:p>

-- Create a Queue<o:p></o:p>

declare @rc int<o:p></o:p>

declare @TraceID int<o:p></o:p>

declare @maxfilesize bigint<o:p></o:p>

set @maxfilesize = 5 <o:p></o:p>

<o:p> </o:p>

-- Please replace the text InsertFileNameHere, with an appropriate<o:p></o:p>

-- filename prefixed by a path, e.g., c:\MyFolder\MyTrace. The .trc extension<o:p></o:p>

-- will be appended to the filename automatically. If you are writing from<o:p></o:p>

-- remote server to local drive, please use UNC path and make sure server has<o:p></o:p>

-- write access to your network share<o:p></o:p>

<o:p> </o:p>

exec @rc = sp_trace_create @TraceID output, 0, N'c:\test', @maxfilesize, NULL <o:p></o:p>

if (@rc != 0) goto error<o:p></o:p>

<o:p> </o:p>

-- Client side File and Table cannot be scripted<o:p></o:p>

<o:p> </o:p>

-- Writing to a table is not supported through the SP's<o:p></o:p>

<o:p> </o:p>

-- Set the events<o:p></o:p>

declare @on bit<o:p></o:p>

set @on = 1<o:p></o:p>

exec sp_trace_setevent @TraceID, 12, 1, @on<o:p></o:p>

exec sp_trace_setevent @TraceID, 12, 12, @on<o:p></o:p>

exec sp_trace_setevent @TraceID, 12, 14, @on<o:p></o:p>

<o:p> </o:p>

<o:p> </o:p>

-- Set the Filters<o:p></o:p>

declare @intfilter int<o:p></o:p>

declare @bigintfilter bigint<o:p></o:p>

<o:p> </o:p>

exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Profiler'<o:p></o:p>

set @intfilter = 100<o:p></o:p>

exec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter<o:p></o:p>

<o:p> </o:p>

set @intfilter = 1<o:p></o:p>

exec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter<o:p></o:p>

<o:p> </o:p>

exec sp_trace_setfilter @TraceID, 35, 1, 6, N'pubs'<o:p></o:p>

<o:p> </o:p>

<o:p> </o:p>

-- Set the trace status to start<o:p></o:p>

exec sp_trace_setstatus @TraceID, 1<o:p></o:p>

<o:p> </o:p>

-- display trace id for future references<o:p></o:p>

select TraceID=@TraceID<o:p></o:p>

goto finish<o:p></o:p>

<o:p> </o:p>

error: <o:p></o:p>

select ErrorCode=@rc<o:p></o:p>

<o:p> </o:p>

finish: <o:p></o:p>

go<o:p></o:p>

<o:p> </o:p>

<o:p> </o:p>

<o:p> </o:p>

二、       生成跟踪脚本的最简式<o:p></o:p>

事件探查器建立跟踪, 并设置好各种选项, 完成后运行跟踪<o:p></o:p>

然后生成脚本:<o:p></o:p>

   事件探查器--文件--导出跟踪定义的文件--选择合适的版本.<o:p></o:p>

<o:p> </o:p>

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

exec @rc = sp_trace_create<o:p></o:p>

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

<o:p> </o:p>

<o:p> </o:p>

然后, 在需要跟踪的时候, 运行这个脚本来启动跟踪<o:p></o:p>

<o:p> </o:p>

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

<o:p> </o:p>

<o:p> </o:p>

三、       已知的问题<o:p></o:p>

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

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

SELECT * FROM ::fn_trace_getinfo(0)<o:p></o:p>

<o:p> </o:p>

3.    停止某个跟踪, 可以在sp_trace_create

你可能感兴趣的:(sql,SQL Server,脚本,Access,Go)