您的位置:首页 > 数据库

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

2008-04-08 23:49 357 查看
一、       用脚本启动并设置跟踪的示例通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助/****************************************************//* Created by: SQL Profiler                         *//* Date: 2004/06/19  16:50:05         *//****************************************************/-- Create a Queuedeclare @rc intdeclare @TraceID intdeclare @maxfilesize bigintset @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 eventsdeclare @on bitset @on = 1exec sp_trace_setevent @TraceID, 12, 1, @onexec sp_trace_setevent @TraceID, 12, 12, @onexec sp_trace_setevent @TraceID, 12, 14, @on  -- Set the Filtersdeclare @intfilter intdeclare @bigintfilter bigint exec sp_trace_setfilter @TraceID, 10, 0, 7, N'SQL Profiler'set @intfilter = 100exec sp_trace_setfilter @TraceID, 22, 0, 4, @intfilter set @intfilter = 1exec sp_trace_setfilter @TraceID, 23, 1, 0, @intfilter exec sp_trace_setfilter @TraceID, 35, 1, 6, N'pubs'  -- Set the trace status to startexec sp_trace_setstatus @TraceID, 1 -- display trace id for future referencesselect TraceID=@TraceIDgoto 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      -- 关闭, 彻底释放  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: