數據結構~Sqlserver索引使用的B樹

来源:http://www.cnblogs.com/lori/archive/2017/05/11/6839971.html
-Advertisement-
Play Games

B樹相關概念 在B-樹中查找給定關鍵字的方法是,首先把根結點取來,在根結點所包含的關鍵字K1,…,Kn查找給定的關鍵字(可用順序查找或二分查找法),若找到等於給定值的關鍵字,則查找成功;否則,一定可以確定要查找的關鍵字在Ki與Ki+1之間,Pi為指向子樹根節點的指針,此時取指針Pi所指的結點繼續查找 ...


B樹相關概念

在B-樹中查找給定關鍵字的方法是,首先把根結點取來,在根結點所包含的關鍵字K1,…,Kn查找給定的關鍵字(可用順序查找或二分查找法),若找到等於給定值的關鍵字,則查找成功;否則,一定可以確定要查找的關鍵字在Ki與Ki+1之間,Pi為指向子樹根節點的指針,此時取指針Pi所指的結點繼續查找,直至找到,或指針Pi為空時查找失敗。

時間複雜度

動態查找樹主要有:二叉查找樹(Binary Search Tree),平衡二叉查找樹(Balanced Binary Search Tree),紅黑樹(Red-Black Tree ),B-tree/B+-tree/ B*-tree (B~Tree)。前三者是典型的二叉查找樹結構,其查找的時間複雜度

O(log2N)

與樹的深度相關,那麼降低樹的深度自然會提高查找效率

 在SQLSERVER里的表現

我們都知道sqlserver數據行的存儲結構有兩種:堆(heap)和B樹(binary二叉樹)。學過數據結構的人都知道,二叉樹的優點是:快速使用二分法找到數據,數據頁面使用雙向鏈表首尾相連。再介紹一下數據結構中的堆(heap)。堆中的數據沒有任何順序,數據頁面也不會首尾相連。那怎麼在堆中查找數據呢? 堆的結構及IAM結構如下:

堆表只依靠表裡的IAM頁(索引分配映射頁)將堆的頁面聯繫在一起,IAM中記錄了頁面編號和頁面位置。由此可以通過IAM掃描數據。
      1.很多書中都講到sqlserver數據行的存儲結構有兩種:堆(heap)和B樹(binary二叉樹)。而我覺得sqlserver數據頁的存儲結構有兩種:堆(heap)和B樹(binary二叉樹)
      2.數據都存在頁面中,sqlserver頁面有兩種類型:數據頁和索引頁。索引頁都是按照B樹結構存儲的。
      那麼重點來了:
      不管是聚集索引,還是非聚集索引,索引數據都存放在索引頁中。
      表中如果有聚合索引,那麼數據全部存儲在索引頁中。
      表中如果只有有非聚合索引,那麼數據存在堆頁(也就是實際的數據行),但是索引數據存儲在索引頁中。
      表中如果既有聚集索引,也有非聚集索引,那麼數據和索引都存放在索引頁中。
      B樹結構中,每一個節點就是一個頁面,B樹里會有一頁:root page(亦即是根節點),非聚集索引和聚集索引都是一樣的。
     下麵開始步入正軌介紹索引:
   

   聚集索引:

      有人會問為什麼一張表只能有一個聚集索引,簡單來說因為表只能以一種順序排列在磁碟中,所以表只能有一個聚集索引。而非聚集索引能有好幾個。
      聚集索引因為數據全部存放在索引頁中,所以順著聚集索引就可以查到數據。聚集索引結構如下:

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

-Advertisement-
Play Games
更多相關文章
  • 在cmd里打開mysql 5.7 Command Line Client。 1.cmd顯示Enter password輸入你登錄資料庫時的密碼。然後下麵是一些創建資料庫和表重要的指令。 (1).創建資料庫:creat table 資料庫名; (2).展示你創建的資料庫(已供你選擇你要使用的資料庫): ...
  • 流程式控制制函數 DECODE decode()函數簡介: 主要作用: 將查詢結果翻譯成其他值(即以其他形式表現出來,以下舉例說明); 使用方法: Select decode(columnname,值1,翻譯值1,值2,翻譯值2,…值n,翻譯值n,預設值) From talbename Where … ...
  • 經典web開發組合Lamp環境搭建之mysql安裝詳解 安裝前準備 通過rpm命令檢查centos上是否已經安裝mysql,然後卸載已經存在的mysql版本 通過yum安裝mysql編譯需要的依賴包 下載mysql5.6安裝包,mysql5.6安裝包下載地址:https://dev.mysql.co ...
  • 一張圖,從側面感受一下SQL Server在江湖上的地位在某數據倉庫的客戶端上,這句SQL的執行時成功的,亮點自己找 從圖中可以看到,支持Oracle中||字元串相加操作,這是Oracle特有的語法,支持limit語法,這是MySQL特有的,支持Row_number函數,這是Oracle和SQL S ...
  • SQL Server常用系統表 1、查詢當前資料庫中的用戶表 2、獲取SQL Server允許同時用戶連接的最大數 3、獲取當前指定資料庫的連接信息 4、獲取當前SQL伺服器所有的連接詳細信息 查詢結果包含了:系統進程和用戶進程。如果只是想查用戶進程的話則需採用下麵的方法5 5、獲取自上次啟動 SQ ...
  • 由於資料庫中的數據表和表欄位的字元集和排序規則不統一,找了很多帖子,最後發現如下腳本很好用。 用法兒是:先執行如下腳本生成修改數據表和表欄位的腳本,然後再執行這些生成的腳本 1. 修改指定資料庫中所有varchar類型的表欄位的字元集為UTF8,並將排序規則修改為utf8_general_ci 2. ...
  • 本文操作系統: CentOS 7.2.1511 x86_64MySQL 版本: 5.7.13 1、卸載系統自帶的 mariadb-lib 2、下載 rpm 安裝包 去官網找到最新的 rpm 集合包。現在最新的是 mysql-5.7.13-1.el7.x86_64.rpm-bundle.tar 複製其 ...
  • wIndows用戶登入選擇“資料庫”右鍵選擇“附加”點擊“添加” 打開資料庫,右鍵選中 選擇“任務”→“生成腳本”→“選擇對象”→“編寫整個數據及所有資料庫對象的腳本” →“下一步” “設置腳本編寫選項” →“高級”→點擊 →點擊“常規”→“Script for Server Version” →把 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...