首頁  >  文章  >  資料庫  >  MySQL資料庫中索引有什麼用

MySQL資料庫中索引有什麼用

WBOY
WBOY轉載
2023-06-03 11:18:572533瀏覽

一、MySQL索引簡介

索引是MySQL資料庫為了加快資料查詢的速度,給表中的某一個或是某幾個欄位新增的一種「目錄」。 MySQL的索引是一個特殊的文件,但是InnoDB類型引擎(關於MySQL的引擎我們會在今後的文章中進行講解)的表的索引是表空間的一個組成部分。
MySQL資料庫總共支援5種類型的索引,分別是普通索引、唯一性索引、主鍵索引、複合索引和全文索引,下面,我將對這四種類型的索引一一介紹。

二、MySQL五種型別索引詳解

(一)普通索引

普通索引是MySQL資料庫中的一種普通的索引,新增普通索引的列對資料沒有特別要求,普通索引能起到的作用就是加快差查詢速度。
在建立資料表時加入普通索引SQL語句範例如下:

create table exp(id int , name varchar(20),index exp_name(name));

或是把index換成key,如下:

create table exp (id ,int , name varahcr (20) ,  key exp_name(name));

在上述SQL指令中,key或index表示加上索引,後面緊跟著的是索引名稱,後面括號裡的是要加索引的欄位。
本文介紹的所有索引相關的SQL語句,如果沒有特殊說明,index都可以換成key,為了節省文章篇幅,這一點在以後就不再贅述了。
此外,我們也可以在新增索引時,不指定索引的名稱,這時,MySQL會自動為該索引新增與該欄位同名的索引名稱。
執行結果如下:

MySQL資料庫中索引有什麼用

建立資料表後向表內新新增普通索引SQL語句範例如下:

alter table exp add index exp_id(id);

執行結果如下:

MySQL資料庫中索引有什麼用

建立資料表後刪除普通索引的SQL語句範例如下:

alter table drop index exp_name;

執行結果如下:

MySQL資料庫中索引有什麼用

注意,在上述指令中,exp_name是索引的名字而不是含有索引的欄位的名字,如果我們忘記了該表中的索引名稱,可以執行下列SQL指令進項查詢:

show index from exp;

其中,exp是表名,該指令執行結果如下:

MySQL資料庫中索引有什麼用

從上面幾張圖片可以看出,在新增普通索引後,使用desc查看表結構時,會發現Key列上出現MUL,這表示該列新增有普通索引。

(二)唯一性索引

唯一性索引,是在普通索引的基礎上,要求新增該索引的列所有的值只能出現一次。唯一性索引常用語添加在註入身分證號、學號等欄位中,不可以加在註入名字、等欄位中。
唯一性索引的添加與普通索引幾乎完全相同,只不過要把普通索引的關鍵字key和index換成unique key和unique index。
在建立資料表時加入唯一性索引的SQL語句範例如下:

create table exp (id int, name varchar(20), unique key (name));

上述指令執行結果如下:

MySQL資料庫中索引有什麼用

可以看出,新增唯一性索引的字段,在使用desc指令查詢表結構時,Key列中會顯示UNI,表示該欄位新增了唯一性索引。
在建立資料表後新增唯一性索引的SQL語句實例如下:

MySQL資料庫中索引有什麼用

#刪除唯一性索引的SQL語句範例如下:

alter table exp drop index name;

執行結果如下:

MySQL資料庫中索引有什麼用

(三)主鍵索引

#主鍵索引,是資料庫的所有索引中查詢速度最快的,並且每個資料表只能有1個主鍵索引列。主鍵索引的列,不允許重複的數據,也不允許為空值。
新增、刪除主鍵索引與普通索引和唯一性索引非常相似,只不過將key換成了primary key而已。相關SQL指令如下:

create table exp(id int ,name varchar(20), primary key (id));alter table exp add primary key (id);

新增了主鍵索引的列,會在desc檢視表結構時Key列上顯示PRI,如下所示:

MySQL資料庫中索引有什麼用

# #主鍵索引的刪除可以執行指令:

alter table exp drop primary key;

注意,在該SQL語句總,key不能換成index。

有時,我們在嘗試刪除主鍵索引時,MySQL後拒絕,這可能是因為該字段添加了auto_increment屬性的緣故,我們可以把該字段修飾符刪除,就可以刪除該字段的主鍵索引了,如下所示:

MySQL資料庫中索引有什麼用

(四)复合索引

如果想要创建一个包含不同的列的索引,我们就可以创建符合索引。其实,复合索引在业务场景中应用的非常频繁,比如,如果我们想要记录数据包的内容,则需要将IP和端口号作为标识数据包的依据,这时就可以把IP地址的列和端口号的列创建为复合索引。复合、添加和删除索引创建SQL语句示例如下:

create table exp (ip varchar(15),port int ,primary key (ip,port));
alter table exp add pirmary key(ip ,port);
alter table exp dorp priamary key;

复合索引在创建后,在使用desc查看数据表结构时,会在Key列中发现多个PRI,这就表示这些含有PRI的列就是复合索引的列了。如下所示:

MySQL資料庫中索引有什麼用

注意,复合索引相当于一个多列的主键索引,因此,添加复合索引的任何一个列都不允许数据为空,并且这些列不允许数据完全相同,否则MySQL数据库会报错。如下所示:

MySQL資料庫中索引有什麼用

(五)全文索引

全文索引主要是用于解决大数据量的情况下模糊匹配的问题。如果数据库中某个字段的数据量非常大,那么如果我们想要使用like+通配符的方式进行查找,速度就会变得非常慢。针对这种情况,我们就可以使用全文索引的方式,来加快模糊查询的速度。全文索引的原理便是通过分词技术,分析处文本中关键字及其出现的频率,并依次建立索引。全文索引的使用,与数据库版本、数据表引擎乃至字段类型息息相关,主要限制如下:
1、MySQL3.2版本以后才支持全文索引。
2、MySQL5.7版本以后MySQL才内置ngram插件,全文索引才开始支持中文。
3、MySQL5.6之前的版本,只有MyISAM引擎才支持全文索引。
4、MySQL5.6以后的版本,MyISAM引擎和InnoDB引擎都支持全文索引。
5、只有字段数据类型为char、varchar、以及text的字段才支持添加全文索引。
创建、添加以及删除全文索引SQL命令如下:

create table exp (id int ,content text ,filltext key (content))engine=MyISAM;
alter table exp add fulltext index (content);
alter table exp drop index content;

部分执行结果如下:

MySQL資料庫中索引有什麼用

在创建了全文索引后,也不能够使用like+通配符的方式进行模糊查询,全文索引的使用有其特定的语法,如下所示:

select * from exp where match(content) against ('a');

其中,match后面的括号里是含有全文索引的字段,against后面的括号里是要模糊匹配的内容。
此外,全文索引的作用并不是唯一的,在很多场景下,我们并不会使用MySQL数据库内置的全文索引,而是使用第三方类似的索引以实现相同的功能。

三、MySQL索引使用原则

1、索引是典型的“以空间换时间”的策略,它会消耗计算机存储空间,但是会加快查询速度。
2、索引的添加,尽管加快了在查询时的查询速度,但是会减慢在插入、删除时的速度。因为在插入、删除数据时需要进行额外的索引操作。
3、索引并非越多越好,数据量不大时不需要添加索引。
4、如果一个表的值需要频繁的插入和修改,则不适合建立索引,反制,如果一个表中某个字段的值要经常进行查询、排序和分组的字段则需要建立索引。
5、如果一个字段满足建立唯一性索引的条件,就不要建立普通索引。

以上是MySQL資料庫中索引有什麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除