色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

MySQL數據庫設計之innodb如何設計主鍵索引

洪振霞2年前16瀏覽0評論
MySQL數據庫設計之innodb如何設計主鍵索引?

MySQL數據庫分為兩種存儲引擎MyISAM引擎與InnoDB。其中最主要區別在于InnoDB是聚集索引而MyISAM是非聚集索引。想要知道如何設計lnnoDB主鍵索引,我們則需要先理解其索引是如何實現才能進行合理有效的設計。

InnoDB索引實現

InnoDB使用B+Tree作為索引結構,數據文件本身就是索引文件。在InnoDB中,表數據文件本身就是按B+Tree組織的一個索引結構,這棵樹的葉節點data域保存了完整的數據記錄。這個索引的key是數據表的主鍵,因此InnoDB表數據文件本身就是主索引。

上圖是InnoDB主索引(同時也是數據文件)的示意圖,可以看到葉節點包含了完整的數據記錄如子葉數據文件就可以理解為索引文件,15為key主鍵,這種索引叫做聚集索引。因為InnoDB的數據文件本身要按主鍵聚集,所以InnoDB要求表必須有主鍵(MyISAM可以沒有),如果沒有顯式指定,則MySQL系統會自動選擇一個可以唯一標識數據記錄的列作為主鍵,如果不存在這種列,則MySQL自動為InnoDB表生成一個隱含字段作為主鍵,這個字段長度為6個字節,類型為長整形。

其次,InnoDB的輔助索引data域存儲的是主鍵的值而不是地址。既InnoDB的所有輔助索引都引用主鍵作為data域。例如,下圖子葉中輔助索引Alice的data存的是主鍵的值

所以當使用輔助索引搜索需要檢索兩遍索引:首先檢索輔助索引獲得主鍵,然后用主鍵到主索引中檢索獲得記錄。

設計的思路

在InnoDB的索引實現后我們就可以根據其特性作出相應的設計了,如

不使用過長的字段作為主鍵,因為所有輔助索引都引用了主索引,過長的主索引會令輔助索引變得過大。不使用非唯一的字段作為主鍵在InnoDB,因為InnoDB數據文件本身是一顆B+Tree,非唯一主鍵會造成在插入新記錄時數據文件為了維持B+Tree的特性而頻繁的分裂調整,十分低效,使用自增字段作為主鍵則是一個不錯的方式。

以上就是如何設計InnoDB主鍵索引的方式,思路是設計先要去理解其原理,在理解其原理之后根據其特性結合實際場景業務等即可以做出對應合理設計,希望我的回答對你有所幫助。