亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

MySQL數據庫中索引有什么用

發布時間:2022-03-04 10:42:53 來源:億速云 閱讀:308 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關MySQL數據庫中索引有什么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、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數據庫中索引有什么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肇庆市| 越西县| 班玛县| 扎赉特旗| 泸溪县| 延津县| 乌海市| 宕昌县| 新津县| 莲花县| 开平市| 姚安县| 嫩江县| 咸丰县| 留坝县| 英吉沙县| 茌平县| 灌阳县| 昂仁县| 广灵县| 长岛县| 田阳县| 新宁县| 罗江县| 丹棱县| 城口县| 郸城县| 青州市| 桦川县| 兴海县| 鹤山市| 永春县| 柯坪县| 郓城县| 轮台县| 南川市| 积石山| 弥勒县| 上高县| 印江| 虎林市|