亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL索引總結(jié)(Index Type)

瀏覽:102日期:2023-02-18 16:43:10
目錄
  • MySQL Index
  • 1.創(chuàng)建和刪除索引
  • 2. 索引類(lèi)型

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常用于查詢(xún)比較接近的數(shù)據(jù);hash結(jié)構(gòu)適用于隨機(jī)訪(fǎng)問(wèn)場(chǎng)景,查找每條數(shù)據(jù)時(shí)間幾乎一致。

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

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會(huì)自動(dòng)生成索引名。
若不想用存儲(chǔ)引擎默認(rèn)索引類(lèi)型,可以指定索引類(lèi)型:

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

2. 索引類(lèi)型

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

  • Rtree 適合根據(jù)一條數(shù)據(jù) 找附近的數(shù)據(jù)
  • Hash 適合隨機(jī)讀取數(shù)據(jù)
  • FullText 全文索引,建立倒排索引,適用于判斷字段是否包含問(wèn)題,例如 like“%ss%”
  • Spatial 空間索引,是對(duì)空間數(shù)據(jù)類(lèi)型的字段建立的索引

索引有如下幾種情況:

  • index索引:通常意義的索引
  • unique索引:唯一索引,保證了列不包含重復(fù)的值,對(duì)于多列唯一索引,它保證值的組合不重復(fù)。
  • primary key索引:unique索引的一種,一個(gè)表只能有一個(gè)primary key

MySQL提供多種索引供選擇:

普通索引
最基本的索引類(lèi)型,沒(méi)有唯一性限制,通過(guò)以下方式創(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)一次,即必須唯一。唯一性索引通過(guò)以下方式創(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類(lèi)型列上創(chuàng)建。
通過(guò)alter table 或 create index命令創(chuàng)建全文索引要比記錄插入帶有全文索引的空表更快。

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

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

到此這篇關(guān)于MySQL索引總結(jié)(Index Type)的文章就介紹到這了,更多相關(guān)MySQL Index Type內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: MySQL
相關(guān)文章:
主站蜘蛛池模板: 国产乱理伦片a级在线观看 国产乱理伦片在线观看 | 黄色天堂网站 | 欧美性视频一区二区三区 | 日本一级特黄视频 | 狠狠色狠狠色综合婷婷tag | 成人精品人成网站 | 在线观看扣喷水 | 草草免费观看视频在线 | 国产超薄肉色丝袜的免费网站 | 免费一级欧美大片在线观看 | 深夜成人性视频免费看 | 黄色网址免费大全 | 天天鲁天天爱天天鲁天天 | 九九99热久久精品在线6手机 | 免费看黄网站大全 | 国产玖玖在线观看 | 成人9久久国产精品品 | 十六以下岁女子毛片免费 | 久久国产欧美日韩高清专区 | 尤物在线免费视频 | 午夜影院欧美 | 麻豆传媒免费在线 | 欧美黄视频 | 521香蕉永久播放地址 | 国产一区中文字幕在线观看 | 韩国色网| 亚洲成在人网站天堂一区二区 | 色男人的天堂 | 久久亚洲一区二区 | 日韩一区二区三区在线播放 | 免费观看污污视频 | 精品美女视频在线观看2023 | 欧美在线观看视频免费 | 看黄色一级毛片 | 久久亚洲网 | 国产精品一区二区久久精品涩爱 | 广东毛片 | 玖玖精品在线观看 | 国产日韩精品欧美一区喷水 | 黄色婷婷 | 国产亚洲精品国产 |