首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >维护存储过程-如何在不阻塞复制的情况下进行删除

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

Stack Overflow用户
提问于 2010-11-13 05:40:44
回答 3查看 4.2K关注 0票数 4

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

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

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

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

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-11-13 05:44:48

我发现最好的方法是使用循环小批量删除。根据数据库及其负载的不同,我曾经一次处理100到10,000行。

代码语言:javascript
运行
复制
while (1=1) begin
    delete top(1000)
        from YourTable
        where ...

    if @@rowcount < 1000 break
end /* while */
票数 8
EN

Stack Overflow用户

发布于 2010-11-13 06:00:37

  • 没有DELETE with (NOLOCK)。write语句中的nolock提示专门指DML中需要查找数据的终止子查询。写入(INSERT、DELETE、UPDATE) always lock修改的数据exclusively.
  • Isolation级别不会影响写入。只需使用锁提示,隔离级别仅指读取。在所有隔离级别下写入always lock modified数据。
  • lock不影响事务性复制。lgo读取器代理读取日志,而不是表。只有合并复制可能受到锁定的影响,但发布到报表服务器不能成为合并复制方案,因为报表服务器没有更新数据的业务。
票数 3
EN

Stack Overflow用户

发布于 2010-11-13 05:48:31

在您指向的文档中建议使用SET TRANSACTION ISOLATION LEVEL SNAPSHOTSET TRANSACTION ISOLATION LEVEL READ COMMITTED

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4169283

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档