成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

1分鐘了解MyISAM與InnoDB的索引差異

數據庫 MySQL 開發工具
數據庫的索引分為主鍵索引(Primary Inkex)與普通索引(Secondary Index)。InnoDB和MyISAM是怎么利用B+樹來實現這兩類索引,其又有什么差異呢?這是今天要聊的內容。

《數據庫索引,到底是什么做的?》介紹了B+樹,它是一種非常適合用來做數據庫索引的數據結構:

(1)很適合磁盤存儲,能夠充分利用局部性原理,磁盤預讀;

(2)很低的樹高度,能夠存儲大量數據;

(3)索引本身占用的內存很?。?/p>

(4)能夠很好的支持單點查詢,范圍查詢,有序性查詢;

數據庫的索引分為主鍵索引(Primary Inkex)與普通索引(Secondary Index)。InnoDB和MyISAM是怎么利用B+樹來實現這兩類索引,其又有什么差異呢?這是今天要聊的內容。

一、MyISAM的索引

MyISAM的索引與行記錄是分開存儲的,叫做非聚集索引(UnClustered Index)。

其主鍵索引與普通索引沒有本質差異:

  • 有連續聚集的區域單獨存儲行記錄
  • 主鍵索引的葉子節點,存儲主鍵,與對應行記錄的指針
  • 普通索引的葉子結點,存儲索引列,與對應行記錄的指針

畫外音:MyISAM的表可以沒有主鍵。

主鍵索引與普通索引是兩棵獨立的索引B+樹,通過索引列查找時,先定位到B+樹的葉子節點,再通過指針定位到行記錄。

舉個例子,MyISAM:

  1. t(id PK, name KEY, sex, flag); 

表中有四條記錄: 

  1. 1, shenjian, m, A  
  2. 3, zhangsan, m, A  
  3. 5, lisi, m, A  
  4. 9, wangwu, f, B 

 

其B+樹索引構造如上圖:

  • 行記錄單獨存儲
  • id為PK,有一棵id的索引樹,葉子指向行記錄
  • name為KEY,有一棵name的索引樹,葉子也指向行記錄

二、InnoDB的索引

InnoDB的主鍵索引與行記錄是存儲在一起的,故叫做聚集索引(Clustered Index):

  • 沒有單獨區域存儲行記錄
  • 主鍵索引的葉子節點,存儲主鍵,與對應行記錄(而不是指針)
  • 畫外音:因此,InnoDB的PK查詢是非??斓摹?/li>

因為這個特性,InnoDB的表必須要有聚集索引:

(1)如果表定義了PK,則PK就是聚集索引;

(2)如果表沒有定義PK,則***個非空unique列是聚集索引;

(3)否則,InnoDB會創建一個隱藏的row-id作為聚集索引;

聚集索引,也只能夠有一個,因為數據行在物理磁盤上只能有一份聚集存儲。

InnoDB的普通索引可以有多個,它與聚集索引是不同的:

  • 普通索引的葉子節點,存儲主鍵(也不是指針)

對于InnoDB表,這里的啟示是:

(1)不建議使用較長的列做主鍵,例如char(64),因為所有的普通索引都會存儲主鍵,會導致普通索引過于龐大;

(2)建議使用趨勢遞增的key做主鍵,由于數據行與索引一體,這樣不至于插入記錄時,有大量索引分裂,行記錄移動;

仍是上面的例子,只是存儲引擎換成InnoDB:

  1. t(id PK, name KEY, sex, flag); 

表中還是四條記錄: 

  1. 1, shenjian, m, A  
  2. 3, zhangsan, m, A  
  3. 5, lisi, m, A  
  4. 9, wangwu, f, B 

 

其B+樹索引構造如上圖:

  • id為PK,行記錄和id索引樹存儲在一起
  • name為KEY,有一棵name的索引樹,葉子存儲id

當: 

  1. select * from t where name=‘lisi’; 

會先通過name輔助索引定位到B+樹的葉子節點得到id=5,再通過聚集索引定位到行記錄。

畫外音:所以,其實掃了2遍索引樹。

三、總結

MyISAM和InnoDB都使用B+樹來實現索引:

  • MyISAM的索引與數據分開存儲
  • MyISAM的索引葉子存儲指針,主鍵索引與普通索引無太大區別
  • InnoDB的聚集索引和數據行統一存儲
  • InnoDB的聚集索引存儲數據行本身,普通索引存儲主鍵
  • InnoDB一定有且只有一個聚集索引
  • InnoDB建議使用趨勢遞增整數作為PK,而不宜使用較長的列作為PK 

【本文為51CTO專欄作者“58沈劍”原創稿件,轉載請聯系原作者】

戳這里,看該作者更多好文

 

責任編輯:龐桂玉 來源: 架構師之路
相關推薦

2021-08-27 08:51:47

MyISAMInnoDB索引

2018-03-12 21:31:24

區塊鏈

2018-03-12 14:37:50

區塊鏈比特幣架構

2017-07-06 08:12:02

索引查詢SQL

2018-03-23 11:23:14

2018-03-23 11:56:09

相似性推薦推薦算法推薦

2017-02-22 14:46:04

Leader-Foll線程

2018-03-23 11:46:49

基于內容的推薦職位推薦集群

2018-03-23 11:33:56

協同過濾程序算法

2024-06-25 12:25:12

LangChain路由鏈

2018-05-06 16:26:03

關聯規則數據分析關聯規則推薦

2009-11-05 14:53:54

Visual Stud

2021-10-19 07:27:08

HTTP代理網絡

2020-10-13 18:22:58

DevOps工具開發

2021-04-30 16:23:58

WebRTC實時音頻

2023-09-07 23:52:50

Flink代碼

2022-12-16 09:55:50

網絡架構OSI

2015-10-23 17:47:32

BaaSPaaS移動中間件

2017-12-26 16:24:36

接口代碼數據

2021-01-27 18:15:01

Docker底層宿主機
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: av手机在线 | 亚洲黄色网址视频 | 成人一区在线观看 | 日本不卡一区 | 在线午夜 | 毛片免费在线 | www日韩高清 | 日韩不卡一二区 | .国产精品成人自产拍在线观看6 | 亚洲成人一区二区 | 国产成人精品免费 | 成人国产在线观看 | 狠狠躁夜夜躁人人爽天天高潮 | 日本网站在线看 | 国产精品毛片无码 | 日韩综合在线视频 | 精品久久一区 | 一区二区三区久久久 | 操操日| 特黄特色大片免费视频观看 | 国产福利视频导航 | 国产95在线 | 黄色av一区 | 我要看一级片 | av黄色在线| 亚洲一区二区三区在线视频 | 精品成人av | 成人在线视频网址 | 国产精品三级 | 国产精品99精品久久免费 | 九九九久久国产免费 | 欧美中文字幕 | 国产精品欧美一区二区三区不卡 | 九九久久久 | 丁香一区二区 | 久久国产精品一区二区 | 午夜天堂精品久久久久 | 亚州国产 | 中文字幕中文字幕 | 久草热视频| 婷婷综合|