承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

SQL Server里书签查找的性能伤害

管理员 2023-07-11 08:37:36 互联网圈 4 ℃ 0 评论 3990字 收藏

在我的博客上,之前我常常谈到SQL Serverl里的书签查找,还有它们带来的很多问题。在今天的文章里,我想从性能角度进一步谈下书签查找,还有它们如何拉低你全部SQL Server性能。

书签查找——反复循环

如果你的非聚集索引不是个覆盖非聚集索引,SQL Server的查询优化器会引入书签查找。对从非聚集索引你返回的每行,SQL Server需要在聚集索引里或堆表里进行额外的查找操作。

例如当你的的聚集索引包括3层,为了返回必要的信息,对每行,你需要3页额外的读取。因此,查询优化器再履行计划里选择书签查找操作,仅在成心义的时候产生——基于你查询的选择度。下图展现了有书签查找操作的履行计划。

通常人们不会太关注书签查找,由于它们只履行几次。如果你的查询选择度太低,查询优化器会用聚集索引扫描或表扫描运算符直接扫描全部表。但只在SQL Server重用缓存的履行计划,这个计划是有屡次区别运行值,包括书签查找的(基于最初提供的输入值),因此这个情况很容易产生,书签查找反复履行。

为了演示这个性能问题,接下来的查询我指定查询优化器使用特定的非聚集索引。查询本身返回80000行,由于对每一个查询履行,SQL Server需要进行书签查找80000次——反复履行。

CREATE PROCEDURE RetrieveData
AS
SELECT * FROM Table1 WITH (INDEX(idxTable1_Column2))
WHERE Column3 = 2
GO

下图展现了查询履行后的实际履行计划。

履行计划看起来非常恐怖(查询优化器乃至启用了并行计划!),由于书签查找运算符这里履行了80000次,查询本身产生了超过165000个逻辑读!(逻辑读个数可以从STATISTIC IO里获得)。

接下来向你展现下,当你有很多并行用户履行这个糟查询时,SQL Server会产生甚么。我会使用ostress.exe(RML工具的一部份)来摹拟100个并行用户的查询。

ostress.exe -Q”EXEC BookmarkLookupsPerformance.dbo.RetrieveData” -n100 -q

在我的测试系统上花费了近15秒来完成100个并行查询。在此期间,CPU占用很高,由于SQL Server需要嵌套循环运算符来进行书签查找操作。嵌套循环操作固然很占CPU资源。

现在让我们修改索引设计,为这个查询创建覆盖非聚集索引。有了非聚集索引,查询优化器不需要再履行计划里进行书签查找。一个非聚集索引查找就能够返回一样的结果:

CREATE NONCLUSTERED INDEX idxTable1_Column2 ON Table1(Column3)
INCLUDE (Column2)
WITH (DROP_EXISTING = ON)
GO

这次当我们再次用ostress.exe履行同个查询,我们看到每一个查询在5秒内完成。和我们刚才看到的15秒有很大的区分。这就是覆盖非聚集索引的威力:在我们查询里气门要求的数据都可以在非聚集索引里直接找到,因此书签查找就能够避免。

小结

在这个文章里我向你展现了不好的书签查找会伤及性能。因此,对重要的查询快速完成查询非常重要——而使用并行的书签查找的履行计划其实不是好的选择。这里覆盖非聚集索引可以帮到你。下次设计索引时可以斟酌下这个方法。

本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!

文章来源:丸子建站

文章标题:SQL Server里书签查找的性能伤害

https://www.wanzijz.com/view/63213.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信