


MySQL索引分類(lèi)和各自用途
Memory存儲(chǔ)引擎可以選擇Hash或BTree索引,Hash索引只能用于=或<=>的等式比較。
1、普通索引:create index on Tablename(列的列表)
alter table TableName add index (列的列表)
create table TableName([...], index [IndexName] (列的列表)
2、唯一性索引:create unique index
alter ... add unique
主鍵:一種唯一性索引,必須指定為primary key
3、全文索引:從3.23.23版開(kāi)始支持全文索引和全文檢索,F(xiàn)ULLTEXT,
可以在char、varchar或text類(lèi)型的列上創(chuàng)建。
4、單列索引、多列索引:
多個(gè)單列索引與單個(gè)多列索引的查詢(xún)效果不同,因?yàn)椋?/p>
執(zhí)行查詢(xún)時(shí),MySQL只能使用一個(gè)索引,會(huì)從多個(gè)索引中選擇一個(gè)限制最為嚴(yán)格的索引。
5、最左前綴(Leftmost Prefixing):多列索引,例如:fname_lname_age索引,以下的搜索條件MySQL都將使用
fname_lname_age索引:firstname,lastname,age;firstname,lastname;firstname,其他情況將不使用。
二、根據(jù)sql查詢(xún)語(yǔ)句確定創(chuàng)建哪種類(lèi)型的索引,如何優(yōu)化查詢(xún)
選擇索引列:
a.性能優(yōu)化過(guò)程中,選擇在哪個(gè)列上創(chuàng)建索引是最重要的步驟之一。可以考慮使用索引的主要有
兩種類(lèi)型的列:在where子句中出現(xiàn)的列,在join子句中出現(xiàn)的列。
b.考慮列中值的分布,索引的列的基數(shù)越大,索引的效果越好。
c.使用短索引,如果對(duì)字符串列進(jìn)行索引,應(yīng)該指定一個(gè)前綴長(zhǎng)度,可節(jié)省大量索引空間,提升查詢(xún)速度。
d.利用最左前綴
e.不要過(guò)度索引,只保持所需的索引。每個(gè)額外的索引都要占用額外的磁盤(pán)空間,并降低寫(xiě)操作的性能。
在修改表的內(nèi)容時(shí),索引必須進(jìn)行更新,有時(shí)可能需要重構(gòu),因此,索引越多,所花的時(shí)間越長(zhǎng)。
MySQL只對(duì)一下操作符才使用索引:<,<=,=,>,>=,between,in,
以及某些時(shí)候的like(不以通配符%或_開(kāi)頭的情形)。
關(guān)鍵字:MySQL、索引、磁盤(pán)空間
新文章:
- CentOS7下圖形配置網(wǎng)絡(luò)的方法
- CentOS 7如何添加刪除用戶(hù)
- 如何解決centos7雙系統(tǒng)后丟失windows啟動(dòng)項(xiàng)
- CentOS單網(wǎng)卡如何批量添加不同IP段
- CentOS下iconv命令的介紹
- Centos7 SSH密鑰登陸及密碼密鑰雙重驗(yàn)證詳解
- CentOS 7.1添加刪除用戶(hù)的方法
- CentOS查找/掃描局域網(wǎng)打印機(jī)IP講解
- CentOS7使用hostapd實(shí)現(xiàn)無(wú)AP模式的詳解
- su命令不能切換root的解決方法
- 解決VMware下CentOS7網(wǎng)絡(luò)重啟出錯(cuò)
- 解決Centos7雙系統(tǒng)后丟失windows啟動(dòng)項(xiàng)
- CentOS下如何避免文件覆蓋
- CentOS7和CentOS6系統(tǒng)有什么不同呢
- Centos 6.6默認(rèn)iptable規(guī)則詳解