SQL Server2000數(shù)據(jù)表用觸發(fā)器來(lái)生成操作日志
此文章主要向大家講述的是用觸發(fā)器來(lái)生成SQL Server2000數(shù)據(jù)表的實(shí)際操作日志,在實(shí)際操作中有時(shí)如果想知道登錄到數(shù)據(jù)庫(kù)的用戶具體做了什么,于是,記錄用戶執(zhí)行的SQL語(yǔ)句就非常有必要,這將是重要的參考依據(jù)。
我們先建一張日志表(DBLoger)用于保存用戶執(zhí)行的SQL語(yǔ)句:
程序代碼
- Create TABLE DBLoger(
- LoginName nvarchar(50),
- HostName nvarchar(50),
- EventInfo nvarchar(500),
- Parameters int,
- EventType nvarchar(100)
- )
接著再建一個(gè)觸發(fā)器,在用戶對(duì)表進(jìn)行增/刪/改時(shí)觸發(fā),將執(zhí)行的SQL語(yǔ)句記錄到日志表中:
程序代碼
- 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
說(shuō)明:由于dbcc inputbuffer的EventInfo最多只能保存255個(gè)字符,所以一旦執(zhí)行的SQL過(guò)長(zhǎng),日志表中將無(wú)法看到完整的SQL語(yǔ)句!
上述的相關(guān)內(nèi)容就是對(duì)用觸發(fā)器生成SQL Server2000數(shù)據(jù)表的操作日志的描述,希望會(huì)給你帶來(lái)一些幫助在此方面。
【編輯推薦】
- SQL Server 2005數(shù)據(jù)庫(kù)安裝實(shí)例演示
- SQL Server數(shù)據(jù)庫(kù)在安裝時(shí)的注意事項(xiàng)
- SQL Server Compact中的DLL文件與工具
- SQL Server合并復(fù)制性能的提高有哪些方案?
- 遇到SQL Server 2000Bug不可怕!