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

主頁 > 知識庫 > MySQL的索引系統采用B+樹的原因解析

MySQL的索引系統采用B+樹的原因解析

熱門標簽:云南電商智能外呼系統價格 400電話可以辦理嗎 臨清電話機器人 高清地圖標注道路 拉卡拉外呼系統 外東北地圖標注 大眾點評星級酒店地圖標注 智能外呼系統復位 話務外呼系統怎么樣

1.什么是索引?

索引是為了加速對表中數據行的檢索而創建的一種分散的存儲結構。(就好像我們小時候用的字典,有了字典查到對應的字就會變快)

2.為什么需要索引?

首先我們需要了解一些概念和知識

  1. mysql數據存儲在什么地方?----磁盤
  2. 查詢數據比較慢的,一般情況下是卡在哪了? ----IO
  3. (所以我們要提高IO的效率,那么如何提高呢?---- 次數和量兩個層面,例如:搬磚,搬一次和搬十次耗費的力氣是不一樣的,一次搬一塊和一次搬十塊耗費的力氣(占用IO資源)也是不一樣的。所以我們盡可能的在滿足自身需求的前提下,減少和IO的交互)
  4. 去磁盤讀取數據的時候,是用多少讀取多少嘛? ----磁盤預讀
  5. 磁盤預讀:內存跟磁盤在發生數據交互的時候,一般情況下有一個最小的邏輯單元,稱為頁,datapage,頁一般由操作系統決定是多大,一般是4k和8k,而我們在進行數據交互的時候,可以取頁的的整數倍來進行讀取,innodb存儲引擎每次讀取數據為16k
  6. 局部性原理:數據和程序都有聚集成群的傾向,同時之前被訪問過的數據和可能再次被查詢,涉及空間局部性、時間局部性

通過以上幾個概念我們大概知道索引是用來干嘛的了----預先設計好索引系統,等我們查詢數據的時候,減少和IO的交互來提高我們的查詢效率。

3.如何設計索引系統?

我們還是先明白幾個概念

  • 索引存儲在哪?---- 磁盤,查詢數據的時候會優先將索引加載到內存中
  • 索引在存儲的時候需要什么信息?需要存什么字段值?

—— key:實際數據行中儲存的值
—— 文件地址(指針、我們需要找到存儲數據文件在哪就得靠文件地址)
—— offset:偏移量(如果我們要取文件中的某一條數據時,就需要用到偏移量)

  • 上面說的這種格式的數據要使用什么樣的數據結構來儲存?

—— 上面可知我們我們的數據格式是 K-V類型的
知道K-V格式數據那我們就知道使用什么數據結構來儲存了,有哈希表、樹(二叉樹、二分查找樹、二分平衡樹紅黑樹、B樹B+樹
綜上所述,我們可以上面的數據結構來設計我們的索引系統

4.MYSQL索引系統是什么呢?

為什么不按照上面說的格式儲存呢?

眾所周知,mysql的索引系統使用的是B+樹,為什么是B+樹呢?接下來我們逐個分析其他的存儲結構為什么不行。在此之前,我們還是需要了解兩個前置知識----OLAP和OLTP

當我們存儲的數據量越多時,對應建立的索引也會越大,當我們從磁盤讀取到內存時就會產生IO問題,那我們又對索引建立索引嘛?不是的,所以mysql采取的B+樹

5.哈希表

上面是哈希表的存儲結構,我們來探討這類的存儲結構的優缺點
缺點:

  • 哈希沖突會造成數據散列不均勻,會產生大量的線性查詢,比較浪費時間
  • 不支持范圍查詢,當進行范圍查詢的時候,必須要挨個遍歷
  • 對于內存空間的要求比較高(要把全部數據加到到內存中)

優點:
如果是等值查詢,那么會非???/p>

那么在mysql中有沒有hash索引呢?

  • memory存儲引擎使用的是hash索引
  • innodb支持自適應hash

 6.樹

6.1 二叉樹

二叉樹本身是無序的,當我們在進行數據查找時要挨個去跟每個節點進行數據對比,看是否符合我們的數據要求,效率低下

6.2 二分查找樹(Binary Search Tree ,BST)

二分查找樹的特點:插入數據的時候必須有序,左子樹必須小于跟節點,右子樹必須保證大于根節點。所以使用二分查找樹對比二叉樹來顯然提高了查詢效率。
但是如果數據插入是遞增或者遞減的順序的話,二分查找樹就會退化成鏈表,查找效率又降低了

6.3 平衡二叉樹(Balanced Binary Tree, AVL樹)

根據二叉查找樹的所暴露出的問題,我們通過使用AVL樹經過左旋或者右旋讓樹平衡。但是為了保證平衡,在插入數據的時候必須要旋轉,通過插入性能的損失來彌補查詢性能的提升。讀多寫少的情況還好,但是如果我讀寫請求一樣多,那就不合適了。

6.4 紅黑樹

紅黑樹也是經過左旋和右旋讓樹平衡起來,還有變色的行為,最長子樹只要不超過最短子樹的兩倍即可…所以就能讓查詢性能和插入性能近似取得一個平衡,但是隨著數據的插入,發現樹的深度會變深,深的深度越深,意味著IO次數越多,影響數據讀取的效率。

6.5 B樹

針對紅黑樹暴露的問題,那么我們應該如何提高讀取的效率呢?我們能不能從有序的二叉樹,變成有序的多叉樹呢,這樣我們就可以儲存更多的數據

Degree為4表示的是一個節點存儲三個數據值,超過就要變換。那么實際的數據是怎么存儲的呢?我們需要Key完整的數據行

上圖是B樹實際存儲數據的圖,每個節點有三個元素key、指針、數據
查找實例,如果我想找28這個數據,先從磁盤塊1開始發現讀取不到,經對比范圍在p2指針指向的磁盤塊3,還是沒找到,再根據磁盤塊3的p2指針指向磁盤塊8找到28。我們來分析一下,每個磁盤塊大小為16kb,我們查找了三個磁盤塊只需讀取48kb,那么三層B樹能存儲多少條記錄呢?

我們理想化一下,假設key和指針不占用大小,一條數據占用1k的大小,那么磁盤1數據可以存儲16條,磁盤3也是16條,磁盤8也是16條,那么我們只能存儲161616=4096條記錄,這明顯有點少了,而且我們是理想化的,實際key和指針也是占用大小的。

于是乎我們不禁思考,為什么存儲的數據量那么少?
我們發現每層存儲的大小都被data給占用了,那么我們能不能只存儲key跟指針呢?為此就引出了B+樹

6.6 B+樹

B樹到B+樹的演變:非葉子節點不存儲數據,葉子節點才存儲數據

上圖我們可以假設p1和28為一組占用10字節大小,那么第一層可以存儲16000/10=1600個這樣的大小,第二層也是1600,第三層data占用1kb,那就是16條,所以總的存儲1600160016=40960000(4096萬)條記錄

mysql索引結構一般3~4層,但是還要注意一個問題。假設我們就是3層存儲結構,如何存儲更多的數據?
剛剛我們假設的是p1和28為10字節大小,那如果它們是1字節呢,那么存儲總量是160001600010=4096000000。所以就引申出面試一直被提到的建立索引用int還是var好?

答:保證key的長度越小也好,varchar小于4字節用varcahr,大于4字節用int

根據B+樹的特點,存儲量大,查詢快,所以mysql使用的就是B+樹

總結

至此mysql索引系統為什么使用的是B+樹就講述完了,如果有什么講錯的地方希望能提醒我改正過來。

到此這篇關于MySQL的索引系統采用B+樹的原因解析的文章就介紹到這了,更多相關MySQL索引B+樹內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • mysql 使用B+樹索引有哪些優勢
  • MySQL用B+樹作為索引結構有什么好處
  • 為什么MySQL數據庫索引選擇使用B+樹?

標簽:福州 溫州 山西 三明 無錫 阿里 定西 揚州

巨人網絡通訊聲明:本文標題《MySQL的索引系統采用B+樹的原因解析》,本文關鍵詞  MySQL,的,索引,系統,采用,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL的索引系統采用B+樹的原因解析》相關的同類信息!
  • 本頁收集關于MySQL的索引系統采用B+樹的原因解析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产福利一区二区三区| 一区二区欧美精品| 精品久久久久久久久久久久久久久 | 亚洲综合区在线| 99在线热播精品免费| 国产亚洲福利社区一区| 狠狠久久亚洲欧美| 国产精品久久夜| 99re这里都是精品| 一区二区三区国产豹纹内裤在线| 色综合久久久久网| 亚洲第一会所有码转帖| 91精品国产高清一区二区三区| 人妖欧美一区二区| 日韩一区二区三区视频在线观看 | 在线日韩av片| 视频一区二区不卡| 国产视频一区在线播放| 91老师国产黑色丝袜在线| 亚洲精品美国一| 欧美videossexotv100| 成人妖精视频yjsp地址| 亚洲激情一二三区| 4hu四虎永久在线影院成人| 国产一区二区精品久久99| 亚洲欧美福利一区二区| 欧美剧情电影在线观看完整版免费励志电影| 日韩—二三区免费观看av| 久久美女高清视频| 色综合视频在线观看| 六月丁香婷婷色狠狠久久| 亚洲理论在线观看| 国产91精品露脸国语对白| 亚洲成人一区在线| 中文字幕国产精品一区二区| 欧美日韩亚洲另类| av在线不卡观看免费观看| 精品一区二区久久久| 亚洲第一福利一区| 亚洲色图制服诱惑| 久久精品亚洲精品国产欧美kt∨ | 91精品国产综合久久精品图片| 国产精品一区不卡| 看国产成人h片视频| 亚洲一区二区av电影| 欧美精品黑人性xxxx| 91在线观看一区二区| 国产美女精品在线| 手机精品视频在线观看| 综合久久久久综合| 国产日韩欧美制服另类| 91精品国产欧美日韩| 欧美日韩性生活| 欧美人与性动xxxx| 95精品视频在线| 成人一区在线观看| 国产麻豆成人传媒免费观看| 午夜av电影一区| 亚洲1区2区3区4区| 亚洲自拍另类综合| 亚洲综合区在线| 亚洲电影第三页| 调教+趴+乳夹+国产+精品| 一区二区三区高清| 亚洲欧美怡红院| 亚洲女人的天堂| 亚洲自拍另类综合| 日韩精品久久理论片| 美国av一区二区| 韩国成人在线视频| 成人a区在线观看| 91官网在线观看| 欧美体内she精高潮| 欧美丝袜自拍制服另类| 欧美二区在线观看| 欧美成人精品福利| 国产日韩精品一区二区浪潮av| 久久久久久久精| 欧美激情一区二区三区在线| 136国产福利精品导航| 国产精品理论片在线观看| 亚洲视频在线观看三级| 亚洲国产中文字幕在线视频综合| 亚洲第一会所有码转帖| 久久精品99久久久| 成人免费视频一区| 欧美肥妇bbw| 国产精品伦一区| 性欧美大战久久久久久久久| 日本午夜精品视频在线观看| 国内精品视频666| 色综合激情久久| 精品久久久三级丝袜| 中文字幕中文字幕中文字幕亚洲无线| 一区二区三区欧美亚洲| 精品午夜久久福利影院| 99久久国产免费看| 91精品国产色综合久久ai换脸| 精品国产乱码久久久久久久| 一区在线观看免费| 日韩国产高清在线| 粉嫩欧美一区二区三区高清影视 | 日本不卡高清视频| 成年人国产精品| 欧美一区二区免费观在线| 中文字幕中文字幕中文字幕亚洲无线| 天天影视色香欲综合网老头| 国产成人免费在线观看不卡| 7777精品久久久大香线蕉| 欧美国产丝袜视频| 午夜精品久久久| av一区二区三区四区| 欧美不卡一二三| 亚洲国产一区视频| 91视频在线观看| 欧美精彩视频一区二区三区| 午夜精品福利一区二区三区av| 大白屁股一区二区视频| 日韩一本二本av| 亚洲国产欧美在线人成| 成人激情综合网站| 日韩欧美在线1卡| 天堂va蜜桃一区二区三区漫画版| 成人小视频免费观看| 精品粉嫩aⅴ一区二区三区四区| 亚洲免费观看高清| 福利91精品一区二区三区| 日韩免费看网站| 日韩电影在线看| 884aa四虎影成人精品一区| 亚洲最快最全在线视频| 欧美曰成人黄网| 亚洲成人免费视| 日本韩国欧美一区| 亚洲女同一区二区| 91网站视频在线观看| 国产欧美精品国产国产专区| 国产一区日韩二区欧美三区| 欧美一区二区人人喊爽| 精品一区二区三区免费播放| 精品处破学生在线二十三| 日韩国产欧美在线观看| 3d动漫精品啪啪1区2区免费| 丝袜美腿一区二区三区| 欧美顶级少妇做爰| 天天综合天天做天天综合| 日韩三级视频在线观看| 黄色精品一二区| 精品区一区二区| 国产成人在线免费观看| 国产精品久久精品日日| 色8久久人人97超碰香蕉987| 亚洲国产欧美在线| 日韩欧美一二区| 精品午夜一区二区三区在线观看| 欧美α欧美αv大片| 美女视频免费一区| 中文欧美字幕免费| 色综合天天性综合| 亚洲电影激情视频网站| 日韩欧美自拍偷拍| 免费三级欧美电影| 久久久久国产精品免费免费搜索| 国产一区欧美一区| 一区二区三区免费在线观看| 在线播放中文字幕一区| 麻豆精品精品国产自在97香蕉| 2024国产精品| 91社区在线播放| 国内精品国产成人国产三级粉色| 中文字幕精品三区| 在线视频国内自拍亚洲视频| 奇米色一区二区| 国产三级精品在线| 99久久精品久久久久久清纯| 五月婷婷激情综合网| 国产视频亚洲色图| 在线观看精品一区| 国产经典欧美精品| 亚洲精品国产视频| 精品久久久久一区| 欧美在线一区二区| 成人av在线影院| 久久成人免费日本黄色| 亚洲视频在线观看三级| 精品国产成人系列| 91超碰这里只有精品国产| 色av成人天堂桃色av| 丁香五精品蜜臀久久久久99网站| 日韩av一二三| 亚洲国产成人av网| 洋洋成人永久网站入口| 亚洲欧洲精品一区二区精品久久久 | 成人美女视频在线观看18| 日韩电影免费一区| 亚洲电影激情视频网站| 精品国产精品一区二区夜夜嗨| 欧美无砖砖区免费| 国产精品小仙女| 日本欧美一区二区在线观看|