SQL Server2000數據表用觸發器來生成操作日志
此文章主要向大家講述的是用觸發器來生成SQL Server2000數據表的實際操作日志,在實際操作中有時如果想知道登錄到數據庫的用戶具體做了什么,于是,記錄用戶執行的SQL語句就非常有必要,這將是重要的參考依據。
我們先建一張日志表(DBLoger)用于保存用戶執行的SQL語句:
程序代碼
- Create TABLE DBLoger(
- LoginName nvarchar(50),
- HostName nvarchar(50),
- EventInfo nvarchar(500),
- Parameters int,
- EventType nvarchar(100)
- )
接著再建一個觸發器,在用戶對表進行增/刪/改時觸發,將執行的SQL語句記錄到日志表中:
程序代碼
- Create TRIGGER Loger ON student
- FOR Insert, Update, Delete
- AS
- SET NOCOUNT ON
- Create TABLE #T(EventType nvarchar(100),Parameters int,EventInfo nvarchar(500))
- Insert #T exec('dbcc inputbuffer(' + @@spid + ')')
記錄到日志表
- Insert INTO DBLoger(LoginName,HostName,EventInfo,Parameters,EventType)
- Select suser_sname(),host_name(),EventInfo,Parameters,EventType FROM #T
說明:由于dbcc inputbuffer的EventInfo最多只能保存255個字符,所以一旦執行的SQL過長,日志表中將無法看到完整的SQL語句!
上述的相關內容就是對用觸發器生成SQL Server2000數據表的操作日志的描述,希望會給你帶來一些幫助在此方面。
【編輯推薦】
- SQL Server 2005數據庫安裝實例演示
- SQL Server數據庫在安裝時的注意事項
- SQL Server Compact中的DLL文件與工具
- SQL Server合并復制性能的提高有哪些方案?
- 遇到SQL Server 2000Bug不可怕!