為什麼視窗聚合函數的邏輯讀取量很高?
在執行計劃中使用公共子表達式假脫機時,邏輯讀取往往會顯著增加對於更大的桌子。經過實驗和觀察執行計劃,發現以下公式似乎成立:
工作表邏輯讀取= 1 NumberOfRows 2 NumberOfGroups 4
然而,🎜> 4
然而,🎜>然而,這個公式的根本原因仍不清楚。本文旨在揭開邏輯讀取計算背後的謎團。
理解視窗聚合函數執行
計畫開始時的段迭代器會向行附加一個標誌指示每個新分割區的開始。隨後,主段假脫機每次檢索一行並將它們插入 tempdb 工作表中。遇到新的群組標誌時,假脫機會將一行返回到嵌套循環運算子的上部輸入。這會觸發工作表行上的流聚合,計算平均值。然後將計算出的平均值與工作表行連接,並截斷工作表以準備下一組。 Segment spool 產生一個虛擬行來處理最後的群組。
工作表的邏輯讀取計算
- 根據我們的理解,工作表是一個堆(或索引假脫機)如果計劃中另有規定)。在提供的範例中,與預期相反,僅需要 11 次邏輯讀取。對於這種差異的解釋如下:
- 向工作表中的行插入每次都會產生一次邏輯讀取,從而導致 3 次邏輯讀取。
- 計算平均值涉及一次邏輯讀取,總共進行 4 次讀取。
- 傳回具有平均列的行涉及四個邏輯
截斷工作表不會產生邏輯讀取。
這使邏輯讀取總數達到4 x 3 = 12,省略了觸發邏輯讀取的第四行的插入只在原作中
結論
理解這個公式的關鍵在於工作表和常規假脫機表的邏輯讀取計數之間的差異。對於工作表,讀取的每一行都被計算為一次邏輯讀取,而對於假脫機表,每個雜湊頁都被計數。
公式與觀察到的執行情況一致:兩個輔助假脫機被讀取兩次(2 COUNT ()),而主線軸發出(COUNT(DISTINCT CustomerID) 1) 行,如附加資訊中所提及的部落格條目所述。額外的一個是由於發出額外的行來指示最後一組的結束。以上是為什麼視窗聚合函數會導致 SQL Server 中如此高的邏輯讀取?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

MySQLhandlesconcurrencyusingamixofrow-levelandtable-levellocking,primarilythroughInnoDB'srow-levellocking.ComparedtootherRDBMS,MySQL'sapproachisefficientformanyusecasesbutmayfacechallengeswithdeadlocksandlacksadvancedfeatureslikePostgreSQL'sSerializa

mySqlHandLestActionSefectefectionalytheinnodbengine,supportingAcidPropertiessimilartopostgresqlesqlandoracle.1)mySqluessRepeTableReadAbereadasTheDefaultIsolationLeleleteLevel,whatcanBeadJustEdToreDtoreDtoreDtoreadCommittedCommittenCommententCommittedForHigh-TrafficsCenarios.2)

最佳實踐包括:1)理解數據結構和MySQL處理方式,2)適當索引,3)避免SELECT*,4)使用合適的JOIN類型,5)謹慎使用子查詢,6)使用EXPLAIN分析查詢,7)考慮查詢對服務器資源的影響,8)定期維護數據庫。這些做法能使MySQL查詢不僅快速,還具備可維護性、可擴展性和資源效率。

MySQLisbetterforspeedandsimplicity,suitableforwebapplications;PostgreSQLexcelsincomplexdatascenarioswithrobustfeatures.MySQLisidealforquickprojectsandread-heavytasks,whilePostgreSQLispreferredforapplicationsrequiringstrictdataintegrityandadvancedSQLf

MySQL通過異步、半同步和組複製三種模式處理數據複製。 1)異步複製性能高但可能丟失數據。 2)半同步複製提高數據安全性但增加延遲。 3)組複製支持多主複製和故障轉移,適用於高可用性需求。

EXPLAIN語句可用於分析和提升SQL查詢性能。 1.執行EXPLAIN語句查看查詢計劃。 2.分析輸出結果,關注訪問類型、索引使用情況和JOIN順序。 3.根據分析結果,創建或調整索引,優化JOIN操作,避免全表掃描,以提升查詢效率。

使用mysqldump進行邏輯備份和MySQLEnterpriseBackup進行熱備份是備份MySQL數據庫的有效方法。 1.使用mysqldump備份數據庫:mysqldump-uroot-pmydatabase>mydatabase_backup.sql。 2.使用MySQLEnterpriseBackup進行熱備份:mysqlbackup--user=root--password=password--backup-dir=/path/to/backupbackup。恢復時,使用相應的命


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Dreamweaver Mac版
視覺化網頁開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器