sql-server – 如何找出谁删除了一些数据SQL Server

我的老板昨天询问了一位客户询问他们如何找出谁删除了他们的sql Server数据库中的一些数据(如果重要的话,这是快递版).

我认为这可以从事务日志中找到(假设它没有被截断) – 这是正确的吗?如果是这样,您如何才能真正找到这些信息呢?

解决方法

我没有尝试过Express上的fn_dblog,但如果它可用,下面的内容将为您提供删除操作:
SELECT 
    * 
FROM 
    fn_dblog(NULL,NULL) 
WHERE 
    Operation = 'LOP_DELETE_ROWS'

获取您感兴趣的交易的交易ID,并识别发起交易的SID:

SELECT
    [Transaction SID]
FROM
    fn_dblog(NULL,NULL)
WHERE
    [Transaction ID] = @TranID
AND
    [Operation] = 'LOP_BEGIN_XACT'

然后从SID中识别用户

SELECT
    *
FROM 
    sysusers
WHERE
    [sid] = @SID

编辑:将所有内容组合在一起以查找指定表上的删除

DECLARE @TableName sysname
SET @TableName = 'dbo.Table_1'

SELECT
    u.[name] AS UserName,l.[Begin Time] AS TransactionStartTime
FROM
    fn_dblog(NULL,NULL) l
INNER JOIN
    (
    SELECT
        [Transaction ID]
    FROM 
        fn_dblog(NULL,NULL) 
    WHERE
        AllocUnitName LIKE @TableName + '%'
    AND
        Operation = 'LOP_DELETE_ROWS'
    ) deletes
ON  deletes.[Transaction ID] = l.[Transaction ID]
INNER JOIN
    sysusers u
ON  u.[sid] = l.[Transaction SID]

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...