MySQL索引分類和各自用途
一、 MySQL: 索引以B樹格式保存
Memory存儲引擎可以選擇Hash或BTree索引,Hash索引只能用于=或<=>的等式比較。
1、普通索引:create index
alter table TableName add index
create table TableName([...], index [IndexName] (列的列表)
2、***性索引:create unique index
alter ... add unique
主鍵:一種***性索引,必須指定為primary key
3、全文索引:從3.23.23版開始支持全文索引和全文檢索,F(xiàn)ULLTEXT,
可以在char、varchar或text類型的列上創(chuàng)建。
4、單列索引、多列索引:
多個單列索引與單個多列索引的查詢效果不同,因為:
執(zhí)行查詢時,MySQL只能使用一個索引,會從多個索引中選擇一個限制最為嚴(yán)格的索引。
5、最左前綴(Leftmost Prefixing):多列索引,例如:fname_lname_age索引,以下的搜索條件MySQL都將使用
fname_lname_age索引:firstname,lastname,age;firstname,lastname;firstname,其他情況將不使用。
二、根據(jù)sql查詢語句確定創(chuàng)建哪種類型的索引,如何優(yōu)化查詢
選擇索引列:
a.性能優(yōu)化過程中,選擇在哪個列上創(chuàng)建索引是最重要的步驟之一。可以考慮使用索引的主要有
兩種類型的列:在where子句中出現(xiàn)的列,在join子句中出現(xiàn)的列。
b.考慮列中值的分布,索引的列的基數(shù)越大,索引的效果越好。
c.使用短索引,如果對字符串列進(jìn)行索引,應(yīng)該指定一個前綴長度,可節(jié)省大量索引空間,提升查詢速度。
d.利用最左前綴
e.不要過度索引,只保持所需的索引。每個額外的索引都要占用額外的磁盤空間,并降低寫操作的性能。
在修改表的內(nèi)容時,索引必須進(jìn)行更新,有時可能需要重構(gòu),因此,索引越多,所花的時間越長。
MySQL只對一下操作符才使用索引:<,<=,=,>,>=,between,in,
以及某些時候的like(不以通配符%或_開頭的情形)。
【編輯推薦】