Pur*_*ome 123 sql t-sql sql-server nolock sql-server-2008
我的业务是制作非关键任务的网站和应用程序- 例如.银行软件,太空飞行,重症监护应用等.你明白了.
那么,有了这个庞大的免责声明,在一些Sql语句中使用NOLOCK提示是不是很糟糕?几年前,一位Sql管理员建议我应该使用NOLOCK,如果我对"脏读"感到满意,这会让我的系统性能提高一些,因为每次读取都没有锁定表/行/不管.
我还被告知,如果我遇到死锁,这是一个很好的解决方案.所以,我开始关注这个想法几年,直到一个Sql大师帮我一些随机代码并注意到我的sql代码中的所有NOLOCKS.我被礼貌地责骂,他试图向我解释(为什么这不是一件好事)而且我迷路了.我觉得他的解释的本质是'它是一个解决更严重问题的创可贴解决方案......特别是如果你遇到了死锁.因此,修复问题的根源.
我最近做了一些谷歌搜索,并发现了这篇文章.
那么,有些sql db guru sensei的请赐教吗?
Geo*_*gas 105
在使用Stack Overflow之前,我反对NOLOCK委托人,你可以使用可能过期或不一致的数据来执行SELECTwith NOLOCK并获取结果.要考虑的一个因素是可以在同一个表中选择数据的同时插入/更新多少记录.如果这种情况发生很多,那么死锁的可能性很高,除非您使用数据库模式,例如READ COMMITED SNAPSHOT.
我已经改变了我对使用NOLOCK后的看法,见证了它如何提高SELECT性能以及消除大量加载的SQL Server上的死锁.有些时候您可能并不关心您的数据是否完全100%提交,即使它们可能已过期,您也需要快速返回结果.
在考虑使用时问自己一个问题NOLOCK:
我的查询是否包含具有大量
INSERT/UPDATE命令的表,我是否关心从查询返回的数据是否可能在给定时刻丢失这些更改?
如果答案是否定的,则使用NOLOCK提高性能.
NOLOCKStack Overflow的代码库中快速搜索了关键字,发现了138个实例,所以我们在很多地方使用它.
OMG*_*ies 67
使用NOLOCK提示,SELECT语句的事务隔离级别为READ UNCOMMITTED.这意味着查询可能会看到脏的和不一致的数据.
这通常不适合申请.即使您的基于Web的关键任务应用程序的脏读行为正常,NOLOCK扫描也可能导致601错误,由于缺少锁定保护而导致数据移动,这将终止查询.
我建议在快照隔离帮助和何时受伤时阅读 - 在大多数情况下,MSDN建议使用READ COMMITTED SNAPSHOT而不是SNAPSHOT.
Mit*_*eat 20
如果您不关心脏读(即主要处于READ状态),那么NOLOCK就可以了.
但是,请注意,大多数锁定问题是由于查询工作负载没有"正确"索引(假设硬件完成任务).
大师的解释是正确的.它通常是解决更严重问题的创可贴解决方案.
编辑:我绝对不建议使用NOLOCK.我想我应该明白这一点.(我只会在极端情况下使用它,我已经分析过它可以).作为一个例子,前一段时间我在一些TSQL上工作,这些TSQL上撒有NOLOCK以试图缓解锁定问题.我删除了所有,实现了正确的索引,所有的死锁都消失了.
Gat*_*ats 13
怀疑这是一个"大师"谁有高流量的经验...
当用户查看完全加载的页面时,网站通常是"脏的".考虑一个从数据库加载然后保存编辑的数据的表单?人们继续谈论肮脏的阅读是不可能的,这是愚蠢的.
也就是说,如果你的选择上有许多层,你可能会构建一个危险的冗余.如果您正在处理资金或状态方案,那么您不仅需要事务性数据读/写,还需要适当的并发解决方案(大多数"大师"都不打扰).
另一方面,如果你有一个高级产品搜索网站(即可能不会被缓存并且有点密集的东西)并且你曾经建立过一个拥有多个并发用户的网站(现象有多少) "专家"没有),它背后的每一个过程都是瓶颈.
知道它的含义并在适当的时候使用它.如今,您的数据库几乎总是您的主要瓶颈,并且使用NOLOCK非常聪明可以为您节省数千美元的基础设施.
编辑:它不仅仅是它所帮助的死锁,它也是你要让其他人等到你完成的程度,反之亦然.
没有一个答案是错误的,但可能有点令人困惑.
| 归档时间: |
|
| 查看次数: |
101766 次 |
| 最近记录: |