您好,欢迎访问一九零五行业门户网

Oracle中如何用T

欢迎进入oracle社区论坛,与200万技术人员互动交流 >>进入 一、用脚本启动并设置跟踪的示例 通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助 /*************************************
欢迎进入oracle社区论坛,与200万技术人员互动交流 >>进入
一、用脚本启动并设置跟踪的示例
通过这个示例,你可以了解用脚本进行跟踪所涉及到的存储过程,要了解这些存储过程的具体语法和参数的含义,请查询联机帮助
/****************************************************//* 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 shareexec @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 bigintexec sp_trace_setfilter @traceid, 10, 0, 7, n'sql profiler'set @intfilter = 100exec sp_trace_setfilter @traceid, 22, 0, 4, @intfilterset @intfilter = 1exec sp_trace_setfilter @traceid, 23, 1, 0, @intfilterexec 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 finisherror: select errorcode=@rcfinish: 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 -- 关闭, 彻底释放
其它类似信息

推荐信息