SQLSERVER預讀邏輯讀物理讀

来源:https://www.cnblogs.com/manjun/archive/2019/11/26/11937669.html
-Advertisement-
Play Games

預讀:用估計信息,去硬碟讀取數據到緩存。預讀100次,也就是估計將要從硬碟中讀取了100頁數據到緩存。 物理讀:查詢計劃生成好以後,如果緩存缺少所需要的數據,讓緩存再次去讀硬碟。物理讀10頁,從硬碟中讀取10頁數據到緩存。 邏輯讀:從緩存中取出所有數據。邏輯讀100次,也就是從緩存里取到100頁數據 ...


  1.   預讀:用估計信息,去硬碟讀取數據到緩存。預讀100次,也就是估計將要從硬碟中讀取了100頁數據到緩存。
  2.   物理讀:查詢計劃生成好以後,如果緩存缺少所需要的數據,讓緩存再次去讀硬碟。物理讀10頁,從硬碟中讀取10頁數據到緩存。
  3.   邏輯讀:從緩存中取出所有數據。邏輯讀100次,也就是從緩存里取到100頁數據。
  4.      lob邏輯讀:從緩存讀取的text,ntext,image或大值類型(varchar(max),nvarchar(max),varbinary(max))的頁的數目

 

SQL Server存儲的最小單位是頁,每一頁大小為8K,SQL Server對於頁的讀取是原子性的,要麼讀完一頁,要麼完全不讀。即使是僅僅要獲得一條數據,也要讀完一頁。而頁之間的數據組織結構為B樹結構。

所以SQL Server對於邏輯讀、預讀、物理讀的單位是頁。

 

基本上,邏輯讀、物理讀、預讀都等於是掃描了多少個頁。

 

 

當遇到一個查詢語句時,SQL SERVER會走第一步,分別為生成執行計劃(占用CPU和記憶體資源),同步的用估計的數據去磁碟中取得需要取的數據(占用IO資源,這就是預讀),

註意,兩個第一步是並行的,SQL SERVER通過這種方式來提高查詢性能.

      然後查詢計劃生成好了以後去緩存讀取數據.當發現緩存缺少所需要的數據後讓緩存再次去讀硬碟(物理讀)

      最後從緩存中取出所有數據(邏輯讀)。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • "Android Battery 架構" Android電源 android中和電源相關的服務有兩個他們在 一個是 ,另一個是在目錄powe下的 。 電源管理架構 Android電源管理主要通過Wakelock機制來管理系統的狀態,整個android電源管理,可以分為四個層次:應用介面層(Power ...
  • 卸載系統自帶MySQL 1. 查看系統當前是否安裝有MySQL rpm -qa|grep -i mysql 2. 卸載當前版本的MySQL yum remove mysql mysql-server mysql-libs mysql-server 卸載過程中出現選擇, 直接"y"就好 再檢查一次無信 ...
  • 註:本篇文章暫時不做流程圖,如果有需求後續補做。 1. 需要準備的源碼文件列表: base部分: kernel\base\core.c kernel\base\bus.c kernel\base\dd.c kernel\base\class.c kernel\base\driver.c 頭文件部分: ...
  • 設置規則 參考 :https://blog.csdn.net/weixin_41004350/article/details/78492367 參考 : https://www.jianshu.com/p/d93e2b177814 定時任務啟動python腳本規則案例 參考:https://www. ...
  • IntelliJ IDEA 簡稱 IDEA,被業界公認為最好的 Java 集成開發工具,尤其在智能代碼助手、代碼自動提示、代碼重構、代碼版本管理(Git、SVN、Maven)、單元測試、代碼分析等方面有著亮眼的發揮。IDEA 產於捷克,開發人員以嚴謹著稱的東歐程式員為主。IDEA 分為社區版和付費版 ...
  • [TOC] 在Linux下麵有相當多的壓縮命令可以運行,這些壓縮命令可以讓我們更方便地從網路上面下載容量較大的文件。 此外,我們知道在Linux下麵,擴展名沒有什麼特殊的意義。 不過,針對這些壓縮命令所產生的壓縮文件,為了方便記憶,還是會有一些特殊的命名方式,就讓我們來看看吧! 文件壓縮 什麼是文件 ...
  • 卸載系統自帶的jdk 1. 查詢系統是否已經安裝了jdk rpm -qa|grep java 2. 卸載已安裝的jdk, 系統可能會自帶多個jdk版本, 按需卸載 rpm -e --nodeps java-1.7.0-openjdk-1.7.0.141-2.6.10.5.el7.x86_64 3.  ...
  • https://sqlserver.code.blog/2019/11/26/missing-msi-and-msp-files/ ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...