我的业务是制作非关键任务的网站和应用程序-> 例如。银行软件、太空飞行、重症监护应用程序等。你明白了。
那么,有了这么大的免责声明,在某些 Sql 语句中使用 NOLOCK 提示是否不好?几年前,一位 Sql 管理员建议我应该使用 NOLOCK,如果我对“脏读”感到满意,这会给我的系统带来更多性能,因为每次读取都不会锁定表/行/随便。
我还被告知,如果我遇到死锁,这是一个很好的解决方案。所以,我开始遵循这个想法几年,直到 Sql 大师帮助我编写一些随机代码并注意到我的 sql 代码中的所有 NOLOCKS。我被礼貌地责骂,他试图向我解释(为什么这不是一件好事),我有点迷路了。我觉得他的解释的本质是'这是一个更严重问题的创可贴解决方案.. 特别是如果你遇到僵局。因此,解决问题的根源'。
我最近做了一些谷歌搜索,发现了这篇文章。
那么,可以请一些sql db guru sensei 赐教吗?