數據結構行編輯成簇 c語言,索引的數據結構及底層存儲

索引是幫助數據庫高效獲取數據的數據結構

索引的數據結構

1.hash表

bVcLSS8

a.利用hash存儲的話需要將所有的數據文件添加到內存,比較耗費內存空間

b.hash表存儲的是無序數據,范圍查找的時候需要挨個進行遍歷,比較耗費時間。

2.二叉樹

bVcLSVf

二叉樹規定左子樹必須小于根節點,右子樹必須大于根節點,可能會導致右子樹變成一條鏈表,對提升查詢效率沒有幫助。

3.平衡樹(AVL樹)

bVcLSWQ

AVL樹是一顆嚴格意義上的平衡樹,它要求最高子樹和最低子樹的高度之差不超過1,因此在進行元素插入的時候,會進行1到n次的旋轉,嚴重影響插入的效率。

4.紅黑樹

bVcLSZy

紅黑樹是基于AVL樹的一個升級,損失了部分查詢的性能,來提升插入的性能,在紅黑樹中,最高子樹不能超過最低子樹的2倍,在插入的時候,不需要進行N多次的旋轉操作,而且加入了變色的特性,來滿足插入和查詢性能的平衡。ps:二叉樹及其變種的其他樹都不能支撐索引的需求,原因是其插入數據的性能比較低,并且樹的深度無法控制,都會因為樹的深度過深而造成io的次數變多,影響讀取數據的效率。

5.B-Tree

bVcLThR

B樹的特點:

1.所有鍵值分布在整顆樹上

2.搜索可能在非葉子節點上結束,在關鍵字全集內做一次查找,性能逼近二分查找

3.節點中的數據索引從左到右遞增排列

缺點:每個節點同時包含了key和data,而每個頁存儲空間是有限的,

如果data比較大的話會導致每個節點存儲的元素數量變小。

當存儲量變大時,會導致深度變大,增大磁盤io次數,進而影響查詢性能。

6.B+Tree

bVcLTEz

B+Tree是在B-Tree的基礎之上做的一種優化:

1.B+Tree的非葉子節點只存儲索引,不存儲data,使非葉子節點可以包含更多的節點,這樣有兩個好處,一是大大降低了樹的高度,二是將數據范圍變成多個區間,增加了檢索的效率。

2.葉子節點存儲所有的索引和data,而且所有的葉子節點相互連接,形成了一種鏈式結構,范圍查詢性能更高。ps:索引的從磁盤到內存的load過程中會產生磁盤I/O消耗,相對于內存讀取,I/O存取的消耗要高好幾個數量級,所以評價一個數據結構作為索引的優劣最重要的指標就是在查找過程中磁盤I/O操作次數。換句話說,索引的結構組織要盡量減少查找過程中磁盤I/O的存取次數。B+Tree這種數據結構利用了磁盤預讀原理,將每個節點的大小設為等于一個頁,每個節點只需要一次I/O就可以載入,并且節點中的數據和索引從左到右遞增排列,符合局部性原理,所以B+Tree擁有更好的性能。

InnoDB索引實現

聚簇索引

在InnoDB這種存儲引擎下,數據和索引是放在一起的.frm存放的是表結構.ibd存放表數據和索引

ps:innoDB存儲引擎默認情況下會把所有的數據文件放到表空間中,不會單獨為每一張表保存一份數據文件,如果需要將每一張表單獨使用文件保存,設置如下屬性:set gobal innodb_file_per_table=on

InnoDB--B+Tree

bVcLTN4

1.葉子節點直接存放索引和數據

2.InnoDB中至少有一個聚簇索引,一般會通過B+Tree對主鍵創建索引,如果沒有主鍵,會選擇唯一鍵,如果沒有唯一鍵,會自動生成一個6位rowid來作為主鍵

3.在非聚簇索引中,葉子節點上存儲的是該行數據的主鍵,然后通過聚簇索引找到對應的數據,也就是要走兩次B+Tree,叫做回表

MyISAM索引實現

非聚簇索引

在MyISAM這種存儲引擎下,數據和索引文件是單獨的文件.frm存放的是表結構.MYI存放索引.MYD存放表數據

MyISAM--B+Tree

bVcLTZt

1.葉子節點存放索引和對應數據的磁盤文件地址

2.MyISAM不存在回表的問題

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/259397.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/259397.shtml
英文地址,請注明出處:http://en.pswp.cn/news/259397.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

卓同學的 Swift 面試題

我覺得應該掌握的知識點,沒有實際意義。 class 和 struct 的區別不通過繼承,代碼復用(共享)的方式有哪些Set 獨有的方法有哪些?實現一個 min 函數,返回兩個元素較小的元素map、filter、reduce 的作用map 與…

使用CImage雙緩沖

一普通顯示:現在的VC顯示圖片非常方便,遠不是VC6.0那個年代的技術可比,而且支持多種格式的如JPG,PNG。 CImage _img; 初始化: _img.Load(L"map.png"); 顯示:OnPaint事件中 CRect rect; this…

匯編語言學習系列 for循環實現

假如匯編語言要實現如下C語言的功能&#xff0c;編譯環境Ubuntu14.04&#xff08;32位&#xff09;。 #include<stdio.h> int fact_for(int n) {int i;int result 1;for(i 2; i < n; i)result * i;return result; }int main(){printf("%d\n", fact_for(3)…

川大錦城c語言期末考試答案,四川大學《計算機組成原理》2018期末考試B卷答案及評分標準.doc...

四川大學期末考試試題(閉卷)答案及評分標準(2017——2018學年第 2 學期) B卷課程號&#xff1a;304036030 課程名稱&#xff1a;計算機組成原理填空題(本大題共15空&#xff0c;每空2分&#xff0c;共30分)在評價計算機性能時用 響應時間 表示計算機完成某任務所需時間;用 吞吐…

2014屆華為校園招聘機試題2

第一題、輸入一個正整數&#xff0c;并編碼為字符串進行輸出 描述: 1、輸入一個正整數&#xff0c;并編碼為字符串進行輸出。 編碼規則為&#xff1a;數字0-9分別編碼為字符a-j 2、輸入肯定是正整數&#xff0c;不用做錯誤較驗 運行時間限制: 無限制 內存限制: 無限制 輸…

圖解phpstorm常用快捷鍵

查詢快捷鍵 CTRLN 查找類 CTRLSHIFTN 全局搜索文件 ,優先文件名匹配的文件 CTRLSHIFTALTN 查找php類名/變量名 ,js方法名/變量名, css 選擇器 CIRLB 找變量的來源&#xff0c;跳到變量申明處 (CTRL 鼠標單擊 也可以) CTRLALTB 找到繼承該接口或者父級 的所有子類, 統計所有子類…

The C Programming Language--可變參數的函數

函數 printf的正確聲明形式為&#xff1a;int printf(char *fmt, ...) void va_start (va list ap, last-required) type va_arg (va list ap, type) void va_end (va list ap) 其中&#xff0c;省略號表示參數表中參數的數量和類型是可變的。 va_list 類型用于聲明一個變量&am…

二分查找法的循環與遞歸實現及時間復雜度分析

轉載&#xff1a;http://baike.baidu.com/link?url3aEK-qcVbYi6ioJOsf-dFmvFQ6WQgzTwnE9JkmlHBc88qk-D00SambfrSl3hVh_UyqyxF8QEUosfq20IQQW5z_ 和http://hi.baidu.com/networkor/item/80d817f8331d8e08a7298834 設數組為整數數組&#xff0c;從小到大排序。二分法強調一定是…

cifar10 c語言,Python3讀取深度學習CIFAR-10數據集出現的若干問題解決

今天在看網上的視頻學習深度學習的時候&#xff0c;用到了CIFAR-10數據集。當我興高采烈的運行代碼時&#xff0c;卻發現了一些錯誤&#xff1a;# -*- coding: utf-8 -*-import pickle as pimport numpy as np import os def load_CIFAR_batch(filename): """ 載…

Java程序性能優化

一、避免在循環條件中使用復雜表達式 在不做編譯優化的情況下&#xff0c;在循環中&#xff0c;循環條件會被反復計算&#xff0c;如果不使用復雜表達式&#xff0c;而使循環條件值不變的話&#xff0c;程序將會運行的更快。 例子&#xff1a; import java.util.vector; class …

asp.net表單提交方法:GET\POST介紹

表單form的提交有兩種方式&#xff0c;一種是get的方法&#xff0c;一種是post 的方法&#xff0c;如果沒有特殊指定&#xff0c;默認為post。看下面代碼,理解ASP.NET Get和Post兩種提交的區別: 1.< form id"form1" method"get" runat"server"…

各種排序算法總結

轉載&#xff1a;http://blog.csdn.net/warringah1/article/details/8951220 明天就要去參加阿里巴巴的實習生筆試了&#xff0c;雖然沒想著能進去&#xff0c;但是態度還是要端正的&#xff0c;也沒什么可以準備的&#xff0c;復習復習排序吧。 1 插入排序 void InsertSort(in…

CentOS7 上安裝 Zookeeper-3.4.9 服務

在 CentOS7 上安裝 zookeeper-3.4.9 服務1、創建 /usr/local/services/zookeeper 文件夾&#xff1a; mkdir -p /usr/local/services/zookeeper 2、進入到 /usr/local/services/zookeeper 目錄中&#xff1a; cd /usr/local/services/zookeeper 3、下載 zookeeper-3.4.9.…

c語言在程序中顯示現在星期幾,C語言程序設計: 輸入年月日 然后輸出是星期幾...

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓#include main(){int year,month,day0,a,b,week,c,i,sum0,days,d;printf("please input year,month,days\n");scanf("%d,%d,%d",&year,&month,&days);for(i1;i{if (year%40){if(year%1000){if (ye…

static之用法

本文轉載于http://www.cnblogs.com/stoneJin/archive/2011/09/21/2183313.html 在C語言中&#xff0c;static的字面意思很容易把我們導入歧途&#xff0c;其實它的作用有三條。 &#xff08;1&#xff09;先來介紹它的第一條也是最重要的一條&#xff1a;隱藏。 當我們同時編譯…

HTTP響應報文與工作原理詳解

HTTP 是一種請求/響應式的協議&#xff0c;即一個客戶端與服務器建立連接后&#xff0c;向服務器發送一個請求;服務器接到請求后&#xff0c;給予相應的響應信息。 超文本傳輸協議(Hypertext Transfer Protocol&#xff0c;簡稱HTTP)是應用層協議。HTTP 是一種請求/響應式的協議…

優先隊列priority_queue 用法詳解

轉載&#xff1a; 1.優先隊列priority_queue 用法詳解 2.STL系列之五 priority_queue 優先級隊列 優先隊列是隊列的一種&#xff0c;不過它可以按照自定義的一種方式&#xff08;數據的優先級&#xff09;來對隊列中的數據進行動態的排序 每次的push和pop操作&#xff0c;隊…

android自定義畫板,android 自定義控件 -- 畫板

如圖&#xff1a;package com.example.myview;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Path;import android.graphics.Paint.Style;import android.util.Attrib…

postgreSQl pathman 用法語句總結

2019獨角獸企業重金招聘Python工程師標準>>> --新建主表 create table part_test(id int, info text, crt_time timestamp not null); --插入測試數據 insert into part_test select id,md5(random()::text),clock_timestamp() (id|| hour)::interval from generat…

Oracle查詢筆記

-- tanslate(str,from_str,to_str) -- 將str中的from_str替換成to_str select translate(hello,e,o) t from dual;-- instr(str,des_str) -- 可以實現like功能 select instr(hello,g),instr(hello,h),instr(hello,l) from dual; -- decode(value,s1,r1,s2,r2,default) -- 類似于…