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

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

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

《數(shù)據(jù)庫(kù)索引,到底是什么做的?》介紹了B+樹(shù),它是一種非常適合用來(lái)做數(shù)據(jù)庫(kù)索引的數(shù)據(jù)結(jié)構(gòu):

(1)很適合磁盤(pán)存儲(chǔ),能夠充分利用局部性原理,磁盤(pán)預(yù)讀;

(2)很低的樹(shù)高度,能夠存儲(chǔ)大量數(shù)據(jù);

(3)索引本身占用的內(nèi)存很小;

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

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

一、MyISAM的索引

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

其主鍵索引與普通索引沒(méi)有本質(zhì)差異:

  • 有連續(xù)聚集的區(qū)域單獨(dú)存儲(chǔ)行記錄
  • 主鍵索引的葉子節(jié)點(diǎn),存儲(chǔ)主鍵,與對(duì)應(yīng)行記錄的指針
  • 普通索引的葉子結(jié)點(diǎn),存儲(chǔ)索引列,與對(duì)應(yīng)行記錄的指針

畫(huà)外音:MyISAM的表可以沒(méi)有主鍵。

主鍵索引與普通索引是兩棵獨(dú)立的索引B+樹(shù),通過(guò)索引列查找時(shí),先定位到B+樹(shù)的葉子節(jié)點(diǎn),再通過(guò)指針定位到行記錄。

舉個(gè)例子,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+樹(shù)索引構(gòu)造如上圖:

  • 行記錄單獨(dú)存儲(chǔ)
  • id為PK,有一棵id的索引樹(shù),葉子指向行記錄
  • name為KEY,有一棵name的索引樹(shù),葉子也指向行記錄

二、InnoDB的索引

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

  • 沒(méi)有單獨(dú)區(qū)域存儲(chǔ)行記錄
  • 主鍵索引的葉子節(jié)點(diǎn),存儲(chǔ)主鍵,與對(duì)應(yīng)行記錄(而不是指針)
  • 畫(huà)外音:因此,InnoDB的PK查詢(xún)是非常快的。

因?yàn)檫@個(gè)特性,InnoDB的表必須要有聚集索引:

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

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

(3)否則,InnoDB會(huì)創(chuàng)建一個(gè)隱藏的row-id作為聚集索引;

聚集索引,也只能夠有一個(gè),因?yàn)閿?shù)據(jù)行在物理磁盤(pán)上只能有一份聚集存儲(chǔ)。

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

  • 普通索引的葉子節(jié)點(diǎn),存儲(chǔ)主鍵(也不是指針)

對(duì)于InnoDB表,這里的啟示是:

(1)不建議使用較長(zhǎng)的列做主鍵,例如char(64),因?yàn)樗械钠胀ㄋ饕紩?huì)存儲(chǔ)主鍵,會(huì)導(dǎo)致普通索引過(guò)于龐大;

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

仍是上面的例子,只是存儲(chǔ)引擎換成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+樹(shù)索引構(gòu)造如上圖:

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

當(dāng): 

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

會(huì)先通過(guò)name輔助索引定位到B+樹(shù)的葉子節(jié)點(diǎn)得到id=5,再通過(guò)聚集索引定位到行記錄。

畫(huà)外音:所以,其實(shí)掃了2遍索引樹(shù)。

三、總結(jié)

MyISAM和InnoDB都使用B+樹(shù)來(lái)實(shí)現(xiàn)索引:

  • MyISAM的索引與數(shù)據(jù)分開(kāi)存儲(chǔ)
  • MyISAM的索引葉子存儲(chǔ)指針,主鍵索引與普通索引無(wú)太大區(qū)別
  • InnoDB的聚集索引和數(shù)據(jù)行統(tǒng)一存儲(chǔ)
  • InnoDB的聚集索引存儲(chǔ)數(shù)據(jù)行本身,普通索引存儲(chǔ)主鍵
  • InnoDB一定有且只有一個(gè)聚集索引
  • InnoDB建議使用趨勢(shì)遞增整數(shù)作為PK,而不宜使用較長(zhǎng)的列作為PK 

【本文為51CTO專(zhuān)欄作者“58沈劍”原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

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

 

責(zé)任編輯:龐桂玉 來(lái)源: 架構(gòu)師之路
相關(guān)推薦

2021-08-27 08:51:47

MyISAMInnoDB索引

2018-03-12 21:31:24

區(qū)塊鏈

2018-03-12 14:37:50

區(qū)塊鏈比特幣架構(gòu)

2017-07-06 08:12:02

索引查詢(xún)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

基于內(nèi)容的推薦職位推薦集群

2018-03-23 11:33:56

協(xié)同過(guò)濾程序算法

2024-06-25 12:25:12

LangChain路由鏈

2018-05-06 16:26:03

關(guān)聯(lián)規(guī)則數(shù)據(jù)分析關(guān)聯(lián)規(guī)則推薦

2009-11-05 14:53:54

Visual Stud

2021-10-19 07:27:08

HTTP代理網(wǎng)絡(luò)

2020-10-13 18:22:58

DevOps工具開(kāi)發(fā)

2021-04-30 16:23:58

WebRTC實(shí)時(shí)音頻

2022-12-16 09:55:50

網(wǎng)絡(luò)架構(gòu)OSI

2023-09-07 23:52:50

Flink代碼

2015-10-23 17:47:32

BaaSPaaS移動(dòng)中間件

2017-12-26 16:24:36

接口代碼數(shù)據(jù)

2021-01-27 18:15:01

Docker底層宿主機(jī)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲一区中文字幕 | 国产精品国产三级国产aⅴ中文 | 国产精品亚洲精品 | 五月激情婷婷六月 | 天堂资源视频 | 国产精品免费看 | 国产黄色在线观看 | 色必久久 | 日韩成人专区 | 欧美另类视频 | 日韩欧美在线视频一区 | 国产精品亚洲视频 | 久久剧场 | 国产蜜臀97一区二区三区 | 91久久精品国产免费一区 | 免费性视频 | 日韩精品一区二区三区免费视频 | 极品销魂美女一区二区 | 日本亚洲欧美 | 亚洲国产精品久久久久秋霞不卡 | 青青草一区二区 | 欧美精品久久久久 | 国产h在线 | 999免费观看视频 | 亚洲一区二区不卡在线观看 | 九九热在线视频 | 欧美中文字幕一区二区三区亚洲 | 欧美高清成人 | h在线播放| 国产精品久久影院 | 精品美女| 亚洲国产一区二区三区在线观看 | 91伊人| 五月天天色 | 色视频网站 | 久操国产 | 免费超碰| 欧美激情a∨在线视频播放 成人免费共享视频 | 成人亚洲精品 | 日干夜操 | 中文字幕日韩欧美一区二区三区 |