第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定

使用SQL Server Audit記錄數(shù)據(jù)庫變更

標(biāo)簽:
SQL Server

    最近工作中有一个需求就是某一个比较重要的业务表经常被莫名其妙的变更。在SQL Server中这类工作如果不事前捕获记录的话无法做到。对于捕获变更来说可以考虑的选择包括TraceCDC。但Trace的成本比较大对于负载量较高的系统并不合适而CDC需要影响业务库因此SQL Server Audit就是一个比较好的选择。

     在SQL Server中如果只是希望获得表的更新时间只需要看表的聚集索引的最后更新时间即可代码如下

SELECT OBJECT_NAME(OBJECT_ID) AS DatabaseName, last_user_update,*  
FROM sys.dm_db_index_usage_stats    
WHERE database_id = DB_ID( 'DateBaseName')    
AND OBJECT_ID=OBJECT_ID('TableName')

 

    但这种方式并不能看到由某人在某个时间修改了某个表在此使用Server Audit。Server Audit底层采用的是扩展事件且存储结构可以以单独文件独立于用户库因此不仅性能较好也不会对用户库产生影响。

    下面是启用审核的T-SQL代码

USE master  
CREATE SERVER AUDIT audit1 TO FILE (FILEPATH='D:\SQLAudit')    
USE AdventureWorks2012    
CREATE DATABASE AUDIT SPECIFICATION SerialPic FOR SERVER AUDIT audit1    
ADD(UPDATE,INSERT,DELETE ON Person.Address by dbo)

 

USE master  
CREATE SERVER AUDIT audit1 TO FILE (FILEPATH='D:\SQLAudit')    
USE AdventureWorks2012    
CREATE DATABASE AUDIT SPECIFICATION SerialPic FOR SERVER AUDIT audit1    
ADD(UPDATE,INSERT,DELETE ON Person.Address by dbo)

 

   上述代码首先创建服务器级别的审核并存入D\SQLAudit中然后对应创建数据库级别的审核。在数据库级别的审核中跟踪Person.Address表的UpdateInsertDelete操作。

 

    接下来尝试修改数据库Person.Address在安全-审核下查看审核日志如图1所示。

图1.查看审核日志

 

    结果如图2所示。

图2.数据库审核记录

 

    这样就可以看到谁在什么时间曾经对该表做过哪些修改。当然除了UI方式也可以通过T-SQL方式查看审核记录。

SELECT * FROM    
fn_get_audit_file('D:\SQLAudit\audit1_B8A7821A-D735-446D-B6FA-DF582AB80375_0_130648999540780000.sqlaudit', default, default)

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消