日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
MyISAM與InnoDB的索引,究竟有什么差異?

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

創(chuàng)新互聯(lián)公司成都企業(yè)網(wǎng)站建設(shè)服務(wù),提供網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)網(wǎng)站開發(fā),網(wǎng)站定制,建網(wǎng)站,網(wǎng)站搭建,網(wǎng)站設(shè)計(jì),成都響應(yīng)式網(wǎng)站建設(shè)公司,網(wǎng)頁(yè)設(shè)計(jì)師打造企業(yè)風(fēng)格網(wǎng)站,提供周到的售前咨詢和貼心的售后服務(wù)。歡迎咨詢做網(wǎng)站需要多少錢:13518219792

一、MyISAM的索引

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

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

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

畫外音:MyISAM的表可以沒有主鍵。 主鍵索引與普通索引是兩棵獨(dú)立的索引B+樹,通過索引列查找時(shí),先定位到B+樹的葉子節(jié)點(diǎn),再通過指針定位到行記錄。

舉個(gè)例子,MyISAM:

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

表中有四條記錄:

  • 1, shenjian, m, A
  • 3, zhangsan, m, A
  • 5, lisi, m, A
  • 9, wangwu, f, B

其B+樹索引構(gòu)造如上圖:

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

二、InnoDB的索引

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

  • 沒有單獨(dú)區(qū)域存儲(chǔ)行記錄;
  • 主鍵索引的葉子節(jié)點(diǎn),存儲(chǔ)主鍵,與對(duì)應(yīng)行記錄(而不是指針);

畫外音:因此,InnoDB的PK查詢是非??斓摹?/p>

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

  • 如果表定義了PK,則PK就是聚集索引;
  • 如果表沒有定義PK,則第一個(gè)非空unique列是聚集索引;
  • 否則,InnoDB會(huì)創(chuàng)建一個(gè)隱藏的row-id作為聚集索引; 

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

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

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

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

  • 不建議使用較長(zhǎng)的列做主鍵,例如char(64),因?yàn)樗械钠胀ㄋ饕紩?huì)存儲(chǔ)主鍵,會(huì)導(dǎo)致普通索引過于龐大;
  • 建議使用趨勢(shì)遞增的key做主鍵,由于數(shù)據(jù)行與索引一體,這樣不至于插入記錄時(shí),有大量索引分裂,行記錄移動(dòng);

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

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

表中還是四條記錄:

  • 1, shenjian, m, A
  • 3, zhangsan, m, A
  • 5, lisi, m, A
  • 9, wangwu, f, B

其B+樹索引構(gòu)造如上圖:

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

當(dāng):

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

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

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

三、總結(jié)

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

  • MyISAM的索引與數(shù)據(jù)分開存儲(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;

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

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


網(wǎng)頁(yè)名稱:MyISAM與InnoDB的索引,究竟有什么差異?
分享地址:http://www.5511xx.com/article/dpijoei.html