MySQL高級知識(三)——索引


前言:索引在sql調優部分占據着重要的位置,了解並深入索引對我們來說也是非常重要的。本篇主要介紹MySQL中索引的相關知識點。


1.索引是什么

MySQL官方對索引的定義:索引(Index)是幫助MySQL高效獲取數據的數據結構。因此索引的本質就是數據結構。索引的目的在於提高查詢效率,可類比字典、書籍的目錄等這種形式。

可簡單理解為“排好序的快速查找數據結構”。在數據之外,數據庫系統還維護着滿足特定查找算法的數據結構,這些數據結構以某種方式指向數據,這樣就可以在這些數據結構上實現高級查找算法,這種數據結構就是索引

一般來說,索引本身也很大,不可能全部存儲在內存中,因此索引往往以索引文件的形式存儲在磁盤上。

平常所說的索引,如果沒有特別指明,都是B樹索引。其中聚集索引、次要索引、覆蓋索引、前綴索引、唯一索引默認都是用B樹。

通過show index from tablename可以查看表的索引情況。

2.索引的優缺點

優點

①類似大學圖書館的書目索引,提高數據的檢索效率,降低數據庫的IO成本。

②通過索引列對數據進行排序,降低數據的排序成本,從而降低CPU的消耗。

缺點

①索引實際上也是一張表,該表保存了主鍵與索引字段,並指向實體表的記錄,所以索引列也要占用空間

②雖然索引大大提高了查詢效率,但是降低了更新表的速度,如insert、update和delete操作。因為更新表時,MySQL不僅要保存數據,還要保存索引文件每次更新的索引列字段,並且在更新操作后,會更新相應字段索引的信息。

③索引只是提高查詢效率的一個因素,如果你的MySQL有大量的數據表,就需要花時間研究建立最優秀的索引或優化查詢語句。

3.索引分類

索引主要分為以下三類:

單值索引:一個索引只包含單個列,一個表可以有多個單值索引。

唯一索引:索引列的值必須唯一,但允許有空值,主鍵就是唯一索引。

復合索引:一個索引包含多個列

索引的結構:

①BTREE索引;②Hash索引;③Full-Text索引;④R-Tree索引。

4.基本語法

①創建索引

create [unique] index indexname on tablename(columnname(length)); alter table tablename add index indexname (columnname(length));

注:如果是char、varchar類型的字段,length可以小於字段實際長度;如果是blob、text類型,必須指定length。

②刪除索引

drop index indexname on tablename;

③查看索引

show index from tablename;

④其他創建索引的方式

1.添加主鍵索引 
ALTER TABLE `table_name` ADD PRIMARY KEY (`column`) 

2.添加唯一索引
ALTER TABLE `table_name` ADD UNIQUE (`column`) 

3.添加全文索引
ALTER TABLE `table_name` ADD FULLTEXT (`column`) 

4.添加普通索引
ALTER TABLE `table_name` ADD INDEX index_name (`column` ) 

5.添加組合索引 
ALTER TABLE `table_name` ADD INDEX index_name (`column1`, `column2`, `column3`)

5.建立索引與否的具體情況

①需建立索引的情況

#1.主鍵自動建立唯一索引。

#2.頻繁作為查詢條件的字段。

#3.查詢中與其他表關聯的字段,外鍵關系建立索引。

#4.高並發下趨向創建組合索引。

#5.查詢中排序的字段,排序字段若通過索引去訪問將大大提高排序速度。

#6.查詢中統計或分組字段。

②不需要創建索引的情況

#1.表記錄太少。(數據量太少MySQL自己就可以搞定了)

#2.經常增刪改的表。

#3.數據重復且平均分配的字段,如國籍、性別,不適合創建索引。

#4.頻繁更新的字段不適合建立索引。

#5.Where條件里用不到的字段不創建索引。


by Shawn Chen,2018.6.21日,下午。


相關內容

MySQL高級知識系列目錄


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM