教你在Oracle中启动脚本跟踪存储过程

作者:网络 来源:佚名 更新时间:2008-11-17 15:07:49 点击:

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

  我们可以用脚本进行跟踪存储过程,当然要了解这些存储过程的具体语法和参数的含义,至于这些语法和参数含义请查询联机帮助。下面请看一实例:

/****************************************************/
/* 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:myfoldermytrace. 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:  est', @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 [email protected]
goto finish
error:
select [email protected]
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   -- 关闭, 彻底释放

商业源码热门下载www.html.org.cn