婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQL Server里書簽查找的性能傷害

SQL Server里書簽查找的性能傷害

熱門標簽:互聯(lián)網(wǎng)電話外呼系統(tǒng) 400電話辦理泰安 電銷需要外呼系統(tǒng)嗎 電話機器人怎么代理商 千呼電話機器人可以試用嗎 零成本地圖標注賺錢 安卡拉地圖標注app 家庭農(nóng)場地圖標注名稱怎樣起名 我要地圖標注數(shù)量有限制嗎

在我的博客上,以前我經(jīng)常談到SQL Serverl里的書簽查找,還有它們帶來的很多問題。在今天的文章里,我想從性能角度進一步談下書簽查找,還有它們?nèi)绾卫湍阏麄€SQL Server性能。

書簽查找——反復(fù)循環(huán)

如果你的非聚集索引不是個覆蓋非聚集索引,SQL Server的查詢優(yōu)化器會引入書簽查找。對于從非聚集索引你返回的每一行,SQL Server需要在聚集索引里或堆表里進行額外的查找操作。

例如當(dāng)你的的聚集索引包含3層,為了返回必要的信息,對于每一行,你需要3頁額外的讀取。因此,查詢優(yōu)化器再執(zhí)行計劃里選擇書簽查找操作,僅在有意義的時候發(fā)生——基于你查詢的選擇度。下圖展示了有書簽查找操作的執(zhí)行計劃。

通常人們不會太關(guān)注書簽查找,因為它們只執(zhí)行幾次。如果你的查詢選擇度太低,查詢優(yōu)化器會用聚集索引掃描或表掃描運算符直接掃描整個表。但只在SQL Server重用緩存的執(zhí)行計劃,這個計劃是有多次不同運行值,包含書簽查找的(基于最初提供的輸入值),因此這個情況很容易發(fā)生,書簽查找反復(fù)執(zhí)行。

為了演示這個性能問題,接下來的查詢我指定查詢優(yōu)化器使用特定的非聚集索引。查詢本身返回80000行,因為對于每個查詢執(zhí)行,SQL Server需要進行書簽查找80000次——反復(fù)執(zhí)行。

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

下圖展示了查詢執(zhí)行后的實際執(zhí)行計劃。

執(zhí)行計劃看起來非常恐怖(查詢優(yōu)化器甚至啟用了并行計劃!),因為書簽查找運算符這里執(zhí)行了80000次,查詢本身產(chǎn)生了超過165000個邏輯讀!(邏輯讀個數(shù)可以從STATISTIC IO里獲取)。

接下來向你展示下,當(dāng)你有很多并行用戶執(zhí)行這個糟糕查詢時,SQL Server會發(fā)生什么。我會使用ostress.exe(RML工具的一部分)來模擬100個并行用戶的查詢。

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

在我的測試系統(tǒng)上花費了近15秒來完成100個并行查詢。在此期間,CPU占用很高,因為SQL Server需要嵌套循環(huán)運算符來進行書簽查找操作。嵌套循環(huán)操作當(dāng)然很占CPU資源。

現(xiàn)在讓我們修改索引設(shè)計,為這個查詢創(chuàng)建覆蓋非聚集索引。有了非聚集索引,查詢優(yōu)化器不需要再執(zhí)行計劃里進行書簽查找。一個非聚集索引查找就可以返回同樣的結(jié)果:

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

這次當(dāng)我們再次用ostress.exe執(zhí)行同個查詢,我們看到每個查詢在5秒內(nèi)完成。和我們剛才看到的15秒有很大的區(qū)別。這就是覆蓋非聚集索引的威力:在我們查詢里氣門請求的數(shù)據(jù)都可以在非聚集索引里直接找到,因此書簽查找就可以避免。

小結(jié)

在這個文章里我向你展示了不好的書簽查找會傷及性能。因此,對于重要的查詢快速完成查詢非常重要——而使用并行的書簽查找的執(zhí)行計劃并不是好的選擇。這里覆蓋非聚集索引可以幫到你。下次設(shè)計索引時可以考慮下這個方法。

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

您可能感興趣的文章:
  • Sql Server查詢性能優(yōu)化之不可小覷的書簽查找介紹

標簽:黃山 來賓 池州 濱州 新鄉(xiāng) 東營 文山 大同

巨人網(wǎng)絡(luò)通訊聲明:本文標題《SQL Server里書簽查找的性能傷害》,本文關(guān)鍵詞  SQL,Server,里,書簽,查找,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server里書簽查找的性能傷害》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server里書簽查找的性能傷害的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 香格里拉县| 扎兰屯市| 沙坪坝区| 张家港市| 金溪县| 历史| 宁都县| 松原市| 上杭县| 高密市| 金昌市| 舞阳县| 淮滨县| 准格尔旗| 武清区| 洛扎县| 永泰县| 子长县| 深圳市| 深泽县| 遵义市| 尚义县| 穆棱市| 迁安市| 丰县| 嘉定区| 徐州市| 磴口县| 闻喜县| 永登县| 福泉市| 大新县| 吕梁市| 张掖市| 常宁市| 临潭县| 朝阳区| 交口县| 赞皇县| 青龙| 龙游县|