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

原创 2006年08月02日 21:40:00

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

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

/****************************************************/

/* 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      -- 关闭, 彻底释放

 

 

T-sql 语句总结

  • 2012年11月27日 11:27
  • 10KB
  • 下载

常用T-SQL语句快速参考

  • 2012年08月15日 13:51
  • 145KB
  • 下载

T-SQL语句之case when then 多条件判断

CASE    WHEN 条件1 THEN 结果1    WHEN 条件2 THEN 结果2    WHEN 条件3 THEN 结果3    WHEN 条件4 THEN 结果4 .........

T-SQL流程控制语句:两个简单的求和练习

T-SQL流程控制语句 练习:用While循环求1~100的偶数和。 练习:计算1~100之间所有能被3整除的数的个数和总和。...

T-SQL语句大全

  • 2011年12月31日 13:27
  • 6.45MB
  • 下载

高级T-SQL语句

  • 2014年09月14日 12:56
  • 710KB
  • 下载

SQLServe_使用T-SQL语句创建数据库、创建表以及表的约束

if exists(select * from sysdatabases where name='school') begin drop database school end go create...

T-SQL实用语句实例

  • 2013年11月05日 11:13
  • 2KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何用T-SQL语句建立跟踪
举报原因:
原因补充:

(最多只允许输入30个字)