溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL索引怎么創(chuàng)建和刪除

發(fā)布時(shí)間:2023-02-07 09:20:46 來源:億速云 閱讀:93 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了MySQL索引怎么創(chuàng)建和刪除的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇MySQL索引怎么創(chuàng)建和刪除文章都會有所收獲,下面我們一起來看看吧。

MySQL Index

索引是一種數(shù)據(jù)結(jié)構(gòu),可以是B-tree、R-tree、或者h(yuǎn)ash結(jié)構(gòu)。其中,B-tree適用于查找某范圍內(nèi)的數(shù)據(jù),可以快速地從當(dāng)前數(shù)據(jù)找到嚇一跳數(shù)據(jù);R-tree常用于查詢比較接近的數(shù)據(jù);hash結(jié)構(gòu)適用于隨機(jī)訪問場景,查找每條數(shù)據(jù)時(shí)間幾乎一致。

優(yōu)化查詢的有效方法是為經(jīng)常查詢的字段建立索引,如無索引查詢數(shù)據(jù)時(shí),會遍歷整張表;若建立索引后查找起來會更快速。當(dāng)進(jìn)行update、delete、insert操作時(shí),mysql會自動更新索引信息。

1.創(chuàng)建和刪除索引

mysql> create index idx_name on tab_name ( col_name );

mysql> alter table tab_name ADD index idx_name ( col_name );

使用create index 需要制定索引名,而用alter table創(chuàng)建時(shí),可以不指定索引名,mysql會自動生成索引名。
若不想用存儲引擎默認(rèn)索引類型,可以指定索引類型:

mysql> alter table tab_name ADD index idx_name ( col_name ) using btree;

2. 索引類型

Btree 適合連續(xù)讀取數(shù)據(jù)

  • Rtree 適合根據(jù)一條數(shù)據(jù) 找附近的數(shù)據(jù)

  • Hash 適合隨機(jī)讀取數(shù)據(jù)

  • FullText 全文索引,建立倒排索引,適用于判斷字段是否包含問題,例如 like“%ss%”

  • Spatial 空間索引,是對空間數(shù)據(jù)類型的字段建立的索引

索引有如下幾種情況:

  • index索引:通常意義的索引

  • unique索引:唯一索引,保證了列不包含重復(fù)的值,對于多列唯一索引,它保證值的組合不重復(fù)。

  • primary key索引:unique索引的一種,一個(gè)表只能有一個(gè)primary key

MySQL提供多種索引供選擇:

普通索引
最基本的索引類型,沒有唯一性限制,通過以下方式創(chuàng)建:
創(chuàng)建索引:create index idx_name on tab_name (col_name);
修改表:Alter table tab_name add index idx_name (col_name);

唯一性索引
與普通索引的區(qū)別:索引列的所有值都只能出現(xiàn)一次,即必須唯一。唯一性索引通過以下方式創(chuàng)建:
創(chuàng)建索引 create unique index idx_name on tab_name (col_name);

主鍵
一種唯一性索引,一個(gè)表只有一個(gè)。
一般在創(chuàng)建表的時(shí)候指定:create table tab_name(…, primary key (col_name));

外鍵
一般Alter table構(gòu)建

全文索引
可以在varchar或者text類型列上創(chuàng)建。
通過alter table 或 create index命令創(chuàng)建全文索引要比記錄插入帶有全文索引的空表更快。

單列索引/多列索引
索引可以是單列索引,也可以是多列索引。為提高搜索效率,需要考慮使用多列索引。
Alter table tab_name add index idx_name (col_name1, col_name2, col_name3);
由于索引文件以B樹格式保存。MySQL可以立即找到合適的col_name1, 然后再轉(zhuǎn)到合適的col_name2, 最后轉(zhuǎn)到合適的col_name3。在沒有掃描數(shù)據(jù)文件任何一個(gè)記錄的情況下,MySQL可以正確地找出了搜索的目標(biāo)記錄。

最左前綴
多列索引在滿足最左前綴時(shí)會被使用:col_name1, col_name2, col_name3;col_name1, col_name2;col_name1。

關(guān)于“MySQL索引怎么創(chuàng)建和刪除”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“MySQL索引怎么創(chuàng)建和刪除”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI