为了账号安全,请及时绑定邮箱和手机立即绑定

SQL Server Audit记录数据库变更

标签:
MySQL SQL Server

    最近工作中有一个需求,就是某一个比较重要的业务表经常被莫名其妙的变更。在SQL Server中这类工作如果不事前捕获记录的话,无法做到。对于捕获变更来说,可以考虑的选择包括Trace,CDC。但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表的Update,Insert,Delete操作。

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

https://img1.sycdn.imooc.com//5acc65f400011abf03310257.jpg

结果如图2所示。

https://img1.sycdn.imooc.com//5acc66070001a87c08550218.jpg

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

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


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消