维护存储过程 - 如何在不阻止复制的情况下删除

fra*_*lic 4 sql-server maintenance sql-server-2005

我们有一个维护存储过程(SQL Server 2005),它从我们的日志表中删除数据.

我们希望避免阻塞,因为我们的日志表已复制到报告服务器.

有什么我可以做的来调整查询以防止阻塞?在将来的sql server版本中将无法使用nolock执行DELETE:http://msdn.microsoft.com/en-us/library/ms187373.aspx

请注意,维护过程每周运行一次,如果我们启用详细日志记录,可能会删除数千行(或数百万行).

Joe*_*lli 8

我发现最好的方法是使用循环来小批量删除.我一次做了100到10,000行,具体取决于数据库及其负载.

while (1=1) begin
    delete top(1000)
        from YourTable
        where ...

    if @@rowcount < 1000 break
end /* while */
Run Code Online (Sandbox Code Playgroud)

  • 删除每批后你还可以添加一个小延迟......类似"WAITFOR DELAY '00:00:02';"(延迟2秒) (2认同)