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

时间:2010-11-12 21:40:44

标签: sql-server sql-server-2005 maintenance

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

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

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

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

3 个答案:

答案 0 :(得分:8)

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

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

    if @@rowcount < 1000 break
end /* while */

答案 1 :(得分:3)

  • 没有DELETE with (NOLOCK)。 write语句中的nolock提示将独占引用到DML中需要查找数据的最终子查询。写入(INSERT,DELETE,UPDATE)始终专门锁定修改后的数据。
  • 隔离级别不会影响写入。 Justa带有锁定提示,隔离级别仅指读取。在所有隔离级别下写入始终锁定已修改的数据。
  • 锁定不会影响事务复制。 lgo reader代理读取 log ,而不是表。只有合并复制可能受锁影响,但发布到报表服务器不能是合并复制方案,因为报表服务器没有业务更新数据。

答案 2 :(得分:2)

您指出的文档中的建议是 SET TRANSACTION ISOLATION LEVEL SNAPSHOTSET TRANSACTION ISOLATION LEVEL READ COMMITTED