程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle中如何用T-SQL語句建立跟蹤

Oracle中如何用T-SQL語句建立跟蹤

編輯:Oracle數據庫基礎

一、用腳本啟動並設置跟蹤的示例

通過這個示例,你可以了解用腳本進行跟蹤所涉及到的存儲過程,要了解這些存儲過程的具體語法和參數的含義,請查詢聯機幫助










/****************************************************/
/* 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     -- 關閉, 徹底釋放
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved