mysql建索引好處 mysql 建立索引的優缺點

2021-10-17 14:00:19 字數 2406 閱讀 9161

建立索引的優缺點:

為什麼要建立索引呢?

這是因為,建立索引可以大大提高系統的效能。

第一、通過建立唯一性索引,可以保證資料庫表中每一行資料的唯一性。

第二、可以大大加快 資料的檢索速度,這也是建立索引的最主要的原因。

第三、可以加速表和表之間的連線,特別是在實現資料的參考完整性方面特別有意義。

第四、在使用分組和排序子句進行資料檢索時,同樣可以顯著減少查詢中分組和排序的時間。

第五、通過使用索引,可以在查詢的過程中,使用優化隱藏器,提高系統的效能。

也許會有人要問:增加索引有如此多的優點,為什麼不對錶中的每乙個列建立乙個索引呢?這種想法固然有其合理性,然而也有其片面性。雖然,索引有許多優點, 但是,為表中的每乙個列都增加索引,是非常不明智的。

這是因為,增加索引也有許多不利的乙個方面:

第一、建立索引和維護索引要耗費時間,這種時間隨著資料量的增加而增加。

第二、索引需要佔物理空間,除了資料表佔資料空間之外,每乙個索引還要佔一定的物理空間。如果要建立聚簇索引,那麼需要的空間就會更大。

第三、當對表中的資料進行增加、刪除和修改的時候,索引也要動態的維護,這樣就降低了資料的維護速度。

什麼樣的字段適合建立索引:

索引是建立在資料庫表中的某些列的上面。因此,在建立索引的時候,應該仔細考慮在哪些列上可以建立索引,在哪些列上不能建立索引。

一般來說,應該在這些列上建立索引,例如:

第一、在經常需要搜尋的列上,可以加快搜尋的速度;

第二、在作為主鍵的列上,強制該列的唯一性和組織表中資料的排列結構;

第三、在經常用在連線的列上,這些列主要是一些外來鍵,可以加快連線的速度;

第四、在經常需要根據範圍進行搜尋的列上建立索引,因為索引已經排序,其指定的範圍是連續的;

第五、在經常需要排序的列上建立索引,因為索引已經排序,這樣查詢可以利用索引的排序,加快排序查詢時間;

第六、在經常使用在where子句中的列上面建立索引,加快條件的判斷速度。

建立索引,一般按照select的where條件來建立,比如: select的條件是where f1 and f2,那麼如果我們在字段f1或字段f2上簡歷索引是沒有用的,只有在字段f1和f2上同時建立索引才有用等。

什麼樣的字段不適合建立索引:

同樣,對於有些列不應該建立索引。一般來說,不應該建立索引的的這些列具有下列特點:

第一,對於那些在查詢中很少使用或者參考的列不應該建立索引。這是因為,既然這些列很少使用到,因此有索引或者無索引,

並不能提高查詢速度。相反,由於增加了索引,反而降低了系統的維護速度和增大了空間需求。

第二,對於那些只有很少資料值的列也不應該增加索引。這是因為,由於這些列的取值很少,例如人事表的性別列,

在查詢的結果中,結果集的資料行佔了表中資料行的很大比 例,即需要在表中搜尋的資料行的比例很大。

增加索引,並不能明顯加快檢索速度。

第三,對於那些定義為text, image和bit資料型別的列不應該增加索引。這是因為,這些列的資料量要麼相當大,要麼取值很少。

第四,當修改效能遠遠大於檢索效能時,不應該建立索 引。這是因為,修改效能和檢索效能是互相矛盾的。

當增加索引時,會提高檢索效能,但是會降低修改效能。當減少索引時,會提高修改效能,降低檢索效能。

因此,當修改效能遠遠大於檢索效能時,不應該建立索引。

建立索引的方法::

1、建立索引,例如 create index on table_name (列的列表);

2、修改表,例如 alter table table_name add index[索引的名字] (列的列表);

3、建立表的時候指定索引,例如create table table_name ( [...], index [索引的名字] (列的列表) );

檢視表中索引的方法:

show index from table_name; 檢視索引

索引的型別及建立例子::

1.primary key (主鍵索引)

mysql> alter table table_name add primary key ( `column` )

2.unique 或 unique key (唯一索引)

mysql> alter table table_name add unique (`column`)

3.fulltext (全文索引)

mysql> alter table table_name add fulltext (`column` )

4.index (普通索引)

mysql> alter table table_name add index index_name ( `column` )

5.多列索引 (聚簇索引)

mysql> alter table `table_name` add index index_name ( `column1`, `column2`, `column3` )

mysql 補建索引 mysql 索引補充

1.unique索引補充 聯合唯一 unique name,email 是name和email這兩列聯合起來唯一,不再試某個字段唯一2.主鍵索引,類似唯一索引,也是允許聯合多個字段作為主鍵,例如 primary nid,name 3.組合索引,多列共同組成索引 注意 例如index name,ema...

mysql 建字首索引 MySQL 字首索引

檢視出現頻率 select count as cnt,city from sakila.city demo group by city order by cnt desc limit 10 1.select count distinct city count from sakila.city dem...

mysql建表建索引6 mysql建表建索引

建表 create table sj projects id int 11 not null auto increment,title varchar 255 not null default comment 專案名稱 platform id int 11 not null default 0 co...