新聞中心
此文章主要向大家講述的是用觸發(fā)器來生成SQL Server2000數(shù)據(jù)表的實(shí)際操作日志,在實(shí)際操作中有時(shí)如果想知道登錄到數(shù)據(jù)庫的用戶具體做了什么,于是,記錄用戶執(zhí)行的SQL語句就非常有必要,這將是重要的參考依據(jù)。

公司主營(yíng)業(yè)務(wù):成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出衡南免費(fèi)做網(wǎng)站回饋大家。
我們先建一張日志表(DBLoger)用于保存用戶執(zhí)行的SQL語句:
程序代碼
- 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語句記錄到日志表中:
程序代碼
- 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個(gè)字符,所以一旦執(zhí)行的SQL過長(zhǎng),日志表中將無法看到完整的SQL語句!
上述的相關(guān)內(nèi)容就是對(duì)用觸發(fā)器生成SQL Server2000數(shù)據(jù)表的操作日志的描述,希望會(huì)給你帶來一些幫助在此方面。
【編輯推薦】
- SQL Server 2005數(shù)據(jù)庫安裝實(shí)例演示
- SQL Server數(shù)據(jù)庫在安裝時(shí)的注意事項(xiàng)
- SQL Server Compact中的DLL文件與工具
- SQL Server合并復(fù)制性能的提高有哪些方案?
- 遇到SQL Server 2000Bug不可怕!
分享標(biāo)題:SQLServer2000數(shù)據(jù)表用觸發(fā)器來生成操作日志
轉(zhuǎn)載注明:http://m.fisionsoft.com.cn/article/dphjccs.html


咨詢
建站咨詢
