- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
理解最终决策就是业务决策,SQL 2008 R2 中运行NOLOCK & READPAST 之间的准确性考虑是什么?在与业务领域讨论变化之前,我想有一个更好的了解。
我继承了许多查询,用于为管理报告创建数据 View 。 “WITH (NOLOCK)”被广泛使用但不一致。正在读取的数据来自不断更新的广泛使用的应用程序的生产服务器。我们正在从 SQL 2005 服务器迁移到 SQL 2008 R2 服务器。这些报告希望数据比存档服务器上 24 小时的旧数据更新鲜。 NOLOCK 的使用表明过去的决定;存在冲突的可能性,精度损失是可以接受的。数据用于填充用于人类意识/决策的仪表板。
所有查询都是 SELECT,对数据 View 登录具有只读访问权限。大多数查询是单表,只有少数 2 和 3 表连接。鉴于低级别的连接 WITH () 似乎是比 SET TRANSACTION ISOLATION LEVEL {} 更好的选择
表提示 (Transact-SQL) http://msdn.microsoft.com/en-us/library/ms187373.aspx(以及关于 SO 的多个问题)表示,除了丢失锁定记录之外,NOLOCK 和/或 READUNCOMMITTED 可能存在重复读取问题。
READPAST 看起来更准确,因为它只会错过锁定的记录而不会出现重复的情况。但我不确定它和 NOLOCK 之间丢失锁定记录的级别是否一致。
Tim Chapman 有一篇比较两者的好文章,但它写于 2007 年,大部分评论围绕 2000 年和 2005 年,其中一条评论表明 READPAST 在 2008 R2
引用
Effect of NOLOCK hint in SELECT statements
When should you use "with (nolock)"
Using NOLOCK and READPAST table hints in SQL Server (By Tim Chapman)
编辑:
下面的两个答案中建议使用快照隔离。快照隔离是数据库的相关设置,这个 Q/A https://serverfault.com/questions/117104/how-can-i-tell-if-snapshot-isolation-is-turned-on 描述了如何查看数据库上的设置。我现在知道它已禁用,我正在阅读来自主要应用程序数据库的报告。更改设置不是一个选项。 +- 百分之几的准确度是可以接受的,应用程序 (OLTP) 影响是 Not Acceptable 。大多数简单查询不需要考虑锁,但在某些极端情况下,需要考虑锁。随着 SQL 2005 快照隔离的出现,关于 SQL 2008 或更高版本中的 NOLOCK & READPAST 行为的信息很少。然而,它们仍然是我唯一的选择。
最佳答案
一个值得考虑的更好的选择是为数据库本身启用 READ COMMITTED SNAPSHOT。这使用 tempdb 中的版本控制来捕获事务开始时表的状态。
在 http://www.brentozar.com/archive/2013/01/implementing-snapshot-or-read-committed-snapshot-isolation-in-sql-server-a-guide/ 上有关于 NOLOCK、READPAST 等各个方面的非常好的阅读
如果在您从中选择时有人正在更新表,则 WITH (NOLOCK)
可能会提供不正确的结果。如果在读取表时由于插入而导致页面拆分,并且新页面恰好超出了您已读取的点,则 WITH (NOLOCK)
将已经从旧页面返回行,然后将返回重复新页面中的行。这只是 (NOLOCK)
不好的一个例子。WITH (READPAST)
将跳过在您从表中读取时正在更新或插入的任何记录。在繁忙的数据库中,这两种选择都不好。
鉴于最近对您的问题进行的编辑,您声明您不能更改 READ COMMITTED SNAPSHOT
的数据库设置,也许您应该考虑使用存储过程来为您的报告收集数据,并在存储过程的开始使用设置事务隔离级别SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
。为此,您需要更改数据库选项“允许快照隔离”。
来自 SQL Server 联机丛书:
快照
指定事务中任何语句读取的数据将是事务开始时存在的数据的事务一致版本。事务只能识别在事务开始之前提交的数据修改。当前事务开始后其他事务所做的数据修改对当前事务中执行的语句是不可见的。效果就像事务中的语句获取事务开始时存在的已提交数据的快照一样。
除了正在恢复数据库时,SNAPSHOT 事务在读取数据时不会请求锁定。 SNAPSHOT 事务读取数据不会阻止其他事务写入数据。写入数据的事务不会阻止 SNAPSHOT 事务读取数据。
在数据库恢复的回滚阶段,如果尝试读取被正在回滚的另一个事务锁定的数据,则 SNAPSHOT 事务将请求锁定。 SNAPSHOT 事务被阻塞,直到该事务被回滚。锁定被授予后立即释放。
在启动使用 SNAPSHOT 隔离级别的事务之前,必须将 ALLOW_SNAPSHOT_ISOLATION 数据库选项设置为 ON。如果使用 SNAPSHOT 隔离级别的事务访问多个数据库中的数据,则必须在每个数据库中将 ALLOW_SNAPSHOT_ISOLATION 设置为 ON。
不能将事务设置为以另一个隔离级别启动的 SNAPSHOT 隔离级别;这样做将导致事务中止。如果事务以 SNAPSHOT 隔离级别启动,您可以将其更改为另一个隔离级别,然后再回到 SNAPSHOT。事务在第一次访问数据时开始。
在 SNAPSHOT 隔离级别下运行的事务可以查看该事务所做的更改。例如,如果事务对表执行 UPDATE,然后针对同一个表发出 SELECT 语句,则修改后的数据将包含在结果集中。
关于SQL 2008+ NOLOCK 与 READPAST 报告准确性的注意事项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15770402/
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!