如何用T-SQL语句建立跟踪
2006-09-16 10:24
399 查看
一般我们会用事件探查器来跟踪SQL Server的运行情况,有时我们也需要定时进行一些跟踪,以检查SQL Server在某个时间段内的运行状况,由于事件探查器不支持调度,因此,应该寻找一种方法,适合我们通过设置JOB来启动跟踪,本文介绍的用T-SQL语句来启用跟踪就适合这种需求。
[align=left]一、 用脚本启动并设置跟踪的示例[/align]
通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助
[align=left]/****************************************************/[/align]
[align=left]/* Created by: SQL Profiler */[/align]
[align=left]/* Date: 2004/06/19 16:50:05 */[/align]
[align=left]/****************************************************/[/align]
[align=left]-- Create a Queue[/align]
[align=left]declare @rc int[/align]
[align=left]declare @TraceID int[/align]
[align=left]declare @maxfilesize bigint[/align]
[align=left]set @maxfilesize = 5 [/align]
[align=left] [/align]
[align=left]-- Please replace the text InsertFileNameHere, with an appropriate[/align]
[align=left]-- filename prefixed by a path, e.g., c:/MyFolder/MyTrace. The .trc extension[/align]
[align=left]-- will be appended to the filename automatically. If you are writing from[/align]
[align=left]-- remote server to local drive, please use UNC path and make sure server has[/align]
[align=left]-- write access to your network share[/align]
[align=left] [/align]
exec @rc = sp_trace_create @
4000
TraceID output, 0, N'c:/test', @maxfilesize, NULL
[align=left]if (@rc != 0) goto error[/align]
[align=left] [/align]
[align=left]-- Client side File and Table cannot be scripted[/align]
[align=left] [/align]
[align=left]-- Writing to a table is not supported through the SP's[/align]
[align=left] [/align]
[align=left]-- Set the events[/align]
[align=left]declare @on bit[/align]
[align=left]set @on = 1[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 1, @on[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 12, @on[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 14, @on[/align]
[align=left] [/align]
[align=left] [/align]
[align=left]-- Set the Filters[/align]
[align=left]declare @intfilter int[/align]
[align=left]declare @bigintfilter bigint[/align]
[align=left] [/align]
[align=left]exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Profiler'[/align]
[align=left]set @intfilter = 100[/align]
[align=left]exec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter[/align]
[align=left] [/align]
[align=left]set @intfilter = 1[/align]
[align=left]exec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter[/align]
[align=left] [/align]
[align=left]exec sp_trace_setfilter @TraceID, 35, 1, 6, N'pubs'[/align]
[align=left] [/align]
[align=left] [/align]
[align=left]-- Set the trace status to start[/align]
[align=left]exec sp_trace_setstatus @TraceID, 1[/align]
[align=left] [/align]
[align=left]-- display trace id for future references[/align]
[align=left]select TraceID=@TraceID[/align]
[align=left]goto finish[/align]
[align=left] [/align]
[align=left]error: [/align]
[align=left]select ErrorCode=@rc[/align]
[align=left] [/align]
[align=left]finish: [/align]
[align=left]go[/align]
[align=left] [/align]
[align=left]二、 生成跟踪脚本的最简式[/align]
事件探查器建立跟踪, 并设置好各种选项, 完成后运行跟踪
然后生成脚本:
事件探查器--文件--导出跟踪定义的文件--选择合适的版本.
这样就会生成一个跟踪的脚本, 打开生成的脚本, 修改里面的:
exec @rc = sp_trace_create
部分, 设置跟踪结果的保存文件(用语句跟踪的时候, 跟踪结果只能保存到文件)
然后, 在需要跟踪的时候, 运行这个脚本来启动跟踪
启动跟踪后, 跟踪自动进行, 所以你可以关闭查询分析器做其他事情去了.
[align=left]三、 已知的问题[/align]
[align=left]1. 跟踪记录不是实时写入跟踪文件的, 因此, 可能会到你停止跟踪的时候, 跟踪信息才写入跟踪文件[/align]
[align=left]2. 查看当前已经进行的跟踪可以用(关于结果集的解释, 请看联机帮助):[/align]
[align=left]SELECT * FROM ::fn_trace_getinfo(0)[/align]
[align=left] [/align]
[align=left]3. 停止某个跟踪, 可以在sp_trace_create 语句中设置自动停止时间, 也可以手动停止跟踪, 用下面的语句:[/align]
[align=left]EXEC sp_trace_setstatus [/align]
[align=left] @traceid = 1 , -- 跟踪的id[/align]
[align=left] @status = 0 -- 停止, 这样以后还可能指定此项为来启用[/align]
[align=left]EXEC sp_trace_setstatus [/align]
[align=left] @traceid = 1 , [/align]
[align=left] @status = 2 -- 关闭, 彻底释放[/align]
[align=left]一、 用脚本启动并设置跟踪的示例[/align]
通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助
[align=left]/****************************************************/[/align]
[align=left]/* Created by: SQL Profiler */[/align]
[align=left]/* Date: 2004/06/19 16:50:05 */[/align]
[align=left]/****************************************************/[/align]
[align=left]-- Create a Queue[/align]
[align=left]declare @rc int[/align]
[align=left]declare @TraceID int[/align]
[align=left]declare @maxfilesize bigint[/align]
[align=left]set @maxfilesize = 5 [/align]
[align=left] [/align]
[align=left]-- Please replace the text InsertFileNameHere, with an appropriate[/align]
[align=left]-- filename prefixed by a path, e.g., c:/MyFolder/MyTrace. The .trc extension[/align]
[align=left]-- will be appended to the filename automatically. If you are writing from[/align]
[align=left]-- remote server to local drive, please use UNC path and make sure server has[/align]
[align=left]-- write access to your network share[/align]
[align=left] [/align]
exec @rc = sp_trace_create @
4000
TraceID output, 0, N'c:/test', @maxfilesize, NULL
[align=left]if (@rc != 0) goto error[/align]
[align=left] [/align]
[align=left]-- Client side File and Table cannot be scripted[/align]
[align=left] [/align]
[align=left]-- Writing to a table is not supported through the SP's[/align]
[align=left] [/align]
[align=left]-- Set the events[/align]
[align=left]declare @on bit[/align]
[align=left]set @on = 1[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 1, @on[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 12, @on[/align]
[align=left]exec sp_trace_setevent @TraceID, 12, 14, @on[/align]
[align=left] [/align]
[align=left] [/align]
[align=left]-- Set the Filters[/align]
[align=left]declare @intfilter int[/align]
[align=left]declare @bigintfilter bigint[/align]
[align=left] [/align]
[align=left]exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Profiler'[/align]
[align=left]set @intfilter = 100[/align]
[align=left]exec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter[/align]
[align=left] [/align]
[align=left]set @intfilter = 1[/align]
[align=left]exec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter[/align]
[align=left] [/align]
[align=left]exec sp_trace_setfilter @TraceID, 35, 1, 6, N'pubs'[/align]
[align=left] [/align]
[align=left] [/align]
[align=left]-- Set the trace status to start[/align]
[align=left]exec sp_trace_setstatus @TraceID, 1[/align]
[align=left] [/align]
[align=left]-- display trace id for future references[/align]
[align=left]select TraceID=@TraceID[/align]
[align=left]goto finish[/align]
[align=left] [/align]
[align=left]error: [/align]
[align=left]select ErrorCode=@rc[/align]
[align=left] [/align]
[align=left]finish: [/align]
[align=left]go[/align]
[align=left] [/align]
[align=left]二、 生成跟踪脚本的最简式[/align]
事件探查器建立跟踪, 并设置好各种选项, 完成后运行跟踪
然后生成脚本:
事件探查器--文件--导出跟踪定义的文件--选择合适的版本.
这样就会生成一个跟踪的脚本, 打开生成的脚本, 修改里面的:
exec @rc = sp_trace_create
部分, 设置跟踪结果的保存文件(用语句跟踪的时候, 跟踪结果只能保存到文件)
然后, 在需要跟踪的时候, 运行这个脚本来启动跟踪
启动跟踪后, 跟踪自动进行, 所以你可以关闭查询分析器做其他事情去了.
[align=left]三、 已知的问题[/align]
[align=left]1. 跟踪记录不是实时写入跟踪文件的, 因此, 可能会到你停止跟踪的时候, 跟踪信息才写入跟踪文件[/align]
[align=left]2. 查看当前已经进行的跟踪可以用(关于结果集的解释, 请看联机帮助):[/align]
[align=left]SELECT * FROM ::fn_trace_getinfo(0)[/align]
[align=left] [/align]
[align=left]3. 停止某个跟踪, 可以在sp_trace_create 语句中设置自动停止时间, 也可以手动停止跟踪, 用下面的语句:[/align]
[align=left]EXEC sp_trace_setstatus [/align]
[align=left] @traceid = 1 , -- 跟踪的id[/align]
[align=left] @status = 0 -- 停止, 这样以后还可能指定此项为来启用[/align]
[align=left]EXEC sp_trace_setstatus [/align]
[align=left] @traceid = 1 , [/align]
[align=left] @status = 2 -- 关闭, 彻底释放[/align]
相关文章推荐
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句来建立启动跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- 如何用T-SQL语句建立跟踪
- SAP Sybase ASA 如何跟踪SQL语句
- 在ACCESS中如何用sql语句建立删除表关系?
- 如何跟踪mysql执行的sql语句
- 用SQL语句来建立跟踪的问题