欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫(kù)之索引詳解

 更新時(shí)間:2021年12月19日 10:56:59   作者:weixin_40228200  
大家好,本篇文章主要講的是MySQL數(shù)據(jù)庫(kù)之索引詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽

今天繼續(xù)給大家介紹MySQL相關(guān)知識(shí),本文主要內(nèi)容是MySQL索引相關(guān)內(nèi)容。

一、MySQL索引簡(jiǎn)介

索引是MySQL數(shù)據(jù)庫(kù)為了加快數(shù)據(jù)查詢的速度,給表中的某一個(gè)或者是某幾個(gè)列添加的一種“目錄”。MySQL的索引是一個(gè)特殊的文件,但是InnoDB類型引擎(關(guān)于MySQL的引擎我們會(huì)在今后的文章中進(jìn)行講解)的表的索引是表空間的一個(gè)組成部分。
MySQL數(shù)據(jù)庫(kù)一共支持5種類型的索引,分別是普通索引、唯一性索引、主鍵索引、復(fù)合索引和全文索引,下面,我將對(duì)這四種類型的索引一一介紹。

二、MySQL五種類型索引詳解

(一)普通索引

普通索引是MySQL數(shù)據(jù)庫(kù)中的一種普通的索引,添加普通索引的列對(duì)數(shù)據(jù)沒(méi)有特殊要求,普通索引能起到的作用就是加快差查詢速度。
在創(chuàng)建數(shù)據(jù)表時(shí)添加普通索引SQL語(yǔ)句示例如下:

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表示添加索引,后面緊跟著的是索引名稱,后面括號(hào)里的是要添加索引的列。
本文介紹的所有索引相關(guān)的SQL語(yǔ)句,如果沒(méi)有特殊說(shuō)明,index都可以換成key,為了節(jié)省文章篇幅,這一點(diǎn)在以后就不再贅述了。
此外,我們也可以在添加索引時(shí),不指定索引的名稱,這時(shí),MySQL會(huì)自動(dòng)為該索引添加與該字段同名的索引名。
執(zhí)行結(jié)果如下:

在這里插入圖片描述

創(chuàng)建數(shù)據(jù)表后向表內(nèi)新添加普通索引SQL語(yǔ)句示例如下:

alter table exp add index exp_id(id);

執(zhí)行結(jié)果如下:

在這里插入圖片描述

創(chuàng)建數(shù)據(jù)表后刪除普通索引的SQL語(yǔ)句示例如下:

alter table drop index exp_name;

執(zhí)行結(jié)果如下:

在這里插入圖片描述

注意,在上述命令中,exp_name是索引的名字而不是含有索引的字段的名字,如果我們忘記了該表中的索引名稱,可以執(zhí)行以下SQL命令進(jìn)項(xiàng)查詢:

show index from exp;

其中,exp是表名,該命令執(zhí)行結(jié)果如下:

在這里插入圖片描述

從上面幾張圖片可以看出,添加普通索引后,在使用desc查看表結(jié)構(gòu)時(shí),會(huì)發(fā)現(xiàn)Key列上出現(xiàn)MUL,這就表示該列添加有普通索引。

(二)唯一性索引

唯一性索引,是在普通索引的基礎(chǔ)上,要求添加該索引的列所有的值只能出現(xiàn)一次。唯一性索引常用語(yǔ)添加在注入身份證號(hào)、學(xué)號(hào)等字段中,不可以添加在注入名字、等字段中。
唯一性索引的添加與普通索引幾乎完全相同,只不過(guò)要把普通索引的關(guān)鍵字key和index換成unique key和unique index。
在創(chuàng)建數(shù)據(jù)表時(shí)添加唯一性索引的SQL語(yǔ)句示例如下:

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

上述命令執(zhí)行結(jié)果如下:

在這里插入圖片描述

可以看出,添加唯一性索引的字段,在使用desc命令查詢表結(jié)構(gòu)時(shí),Key列中會(huì)顯示UNI,表示該字段添加了唯一性索引。
在創(chuàng)建數(shù)據(jù)表后添加唯一性索引的SQL語(yǔ)句實(shí)例如下:

在這里插入圖片描述

刪除唯一性索引的SQL語(yǔ)句示例如下:

alter table exp drop index name;

執(zhí)行結(jié)果如下:

在這里插入圖片描述

(三)主鍵索引

主鍵索引,是數(shù)據(jù)庫(kù)的所有索引中查詢速度最快的,并且每個(gè)數(shù)據(jù)表只能有1個(gè)主鍵索引列。主鍵索引的列,不允許出現(xiàn)重復(fù)的數(shù)據(jù),也不允許為空值。
添加、刪除主鍵索引與普通索引和唯一性索引非常相似,只不過(guò)將key換成了primary key而已。相關(guān)SQL命令如下:

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

添加了主鍵索引的列,會(huì)在desc查看表結(jié)構(gòu)時(shí)Key列上顯示PRI,如下所示:

在這里插入圖片描述

主鍵索引的刪除可以執(zhí)行命令:

alter table exp drop primary key;

注意,在該SQL語(yǔ)句總,key不能換成index。
有時(shí),我們?cè)趪L試刪除主鍵索引時(shí),MySQL后拒絕,這可能是因?yàn)樵撟侄翁砑恿薬uto_increment屬性的緣故,我們可以把該字段修飾符刪除,就可以刪除該字段的主鍵索引了,如下所示:

在這里插入圖片描述

(四)復(fù)合索引

如果想要?jiǎng)?chuàng)建一個(gè)包含不同的列的索引,我們就可以創(chuàng)建符合索引。其實(shí),復(fù)合索引在業(yè)務(wù)場(chǎng)景中應(yīng)用的非常頻繁,比如,如果我們想要記錄數(shù)據(jù)包的內(nèi)容,則需要將IP和端口號(hào)作為標(biāo)識(shí)數(shù)據(jù)包的依據(jù),這時(shí)就可以把IP地址的列和端口號(hào)的列創(chuàng)建為復(fù)合索引。復(fù)合、添加和刪除索引創(chuàng)建SQL語(yǔ)句示例如下:

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;

復(fù)合索引在創(chuàng)建后,在使用desc查看數(shù)據(jù)表結(jié)構(gòu)時(shí),會(huì)在Key列中發(fā)現(xiàn)多個(gè)PRI,這就表示這些含有PRI的列就是復(fù)合索引的列了。如下所示:

在這里插入圖片描述

注意,復(fù)合索引相當(dāng)于一個(gè)多列的主鍵索引,因此,添加復(fù)合索引的任何一個(gè)列都不允許數(shù)據(jù)為空,并且這些列不允許數(shù)據(jù)完全相同,否則MySQL數(shù)據(jù)庫(kù)會(huì)報(bào)錯(cuò)。如下所示:

在這里插入圖片描述

(五)全文索引

全文索引主要是用于解決大數(shù)據(jù)量的情況下模糊匹配的問(wèn)題。如果數(shù)據(jù)庫(kù)中某個(gè)字段的數(shù)據(jù)量非常大,那么如果我們想要使用like+通配符的方式進(jìn)行查找,速度就會(huì)變得非常慢。針對(duì)這種情況,我們就可以使用全文索引的方式,來(lái)加快模糊查詢的速度。全文索引的原理便是通過(guò)分詞技術(shù),分析處文本中關(guān)鍵字及其出現(xiàn)的頻率,并依次建立索引。全文索引的使用,與數(shù)據(jù)庫(kù)版本、數(shù)據(jù)表引擎乃至字段類型息息相關(guān),主要限制如下:
1、MySQL3.2版本以后才支持全文索引。
2、MySQL5.7版本以后MySQL才內(nèi)置ngram插件,全文索引才開始支持中文。
3、MySQL5.6之前的版本,只有MyISAM引擎才支持全文索引。
4、MySQL5.6以后的版本,MyISAM引擎和InnoDB引擎都支持全文索引。
5、只有字段數(shù)據(jù)類型為char、varchar、以及text的字段才支持添加全文索引。
創(chuàng)建、添加以及刪除全文索引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;

部分執(zhí)行結(jié)果如下:

在這里插入圖片描述

在創(chuàng)建了全文索引后,也不能夠使用like+通配符的方式進(jìn)行模糊查詢,全文索引的使用有其特定的語(yǔ)法,如下所示:

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

其中,match后面的括號(hào)里是含有全文索引的字段,against后面的括號(hào)里是要模糊匹配的內(nèi)容。
此外,全文索引的作用并不是唯一的,在很多場(chǎng)景下,我們并不會(huì)使用MySQL數(shù)據(jù)庫(kù)內(nèi)置的全文索引,而是使用第三方類似的索引以實(shí)現(xiàn)相同的功能。

三、MySQL索引使用原則

1、索引是典型的“以空間換時(shí)間”的策略,它會(huì)消耗計(jì)算機(jī)存儲(chǔ)空間,但是會(huì)加快查詢速度。
2、索引的添加,盡管加快了在查詢時(shí)的查詢速度,但是會(huì)減慢在插入、刪除時(shí)的速度。因?yàn)樵诓迦搿h除數(shù)據(jù)時(shí)需要進(jìn)行額外的索引操作。
3、索引并非越多越好,數(shù)據(jù)量不大時(shí)不需要添加索引。
4、如果一個(gè)表的值需要頻繁的插入和修改,則不適合建立索引,反制,如果一個(gè)表中某個(gè)字段的值要經(jīng)常進(jìn)行查詢、排序和分組的字段則需要建立索引。
5、如果一個(gè)字段滿足建立唯一性索引的條件,就不要建立普通索引。

總結(jié)

到此這篇關(guān)于MySQL數(shù)據(jù)庫(kù)之索引詳解的文章就介紹到這了,更多相關(guān)MySQL索引內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于mysql delete的問(wèn)題小結(jié)

    關(guān)于mysql delete的問(wèn)題小結(jié)

    關(guān)于mysql delete的問(wèn)題,需要的朋友可以參考下。
    2011-05-05
  • MySQL無(wú)法啟動(dòng)1067錯(cuò)誤的又一種解決方法(機(jī)房斷電)

    MySQL無(wú)法啟動(dòng)1067錯(cuò)誤的又一種解決方法(機(jī)房斷電)

    今早在對(duì)一張table 創(chuàng)建primay key過(guò)程中發(fā)生了斷電,當(dāng)電腦再次啟動(dòng)時(shí)候,發(fā)現(xiàn)mysql 服務(wù)無(wú)法啟動(dòng),使用 net start 提示 1067錯(cuò)誤,折騰了2個(gè)小時(shí)無(wú)法解決,后來(lái)只能通過(guò)手工刪除數(shù)據(jù)文件,日志文件,再啟動(dòng)服務(wù),然后導(dǎo)入數(shù)據(jù)來(lái)完成
    2013-01-01
  • mysql 循環(huán)insert方式

    mysql 循環(huán)insert方式

    這篇文章主要介紹了mysql 循環(huán)insert方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • MySQL日期加減函數(shù)詳解

    MySQL日期加減函數(shù)詳解

    在本篇文章里小編給大家分享的是關(guān)于MySQL日期加減函數(shù)用法以及實(shí)例,需要的朋友們可以參考下。
    2020-05-05
  • MySQL8.0.20壓縮版本安裝教程圖文詳解

    MySQL8.0.20壓縮版本安裝教程圖文詳解

    這篇文章主要介紹了MySQL8.0.20壓縮版本安裝教程,需本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,要的朋友可以參考下
    2020-08-08
  • centos7下安裝mysql6初始化安裝密碼的方法

    centos7下安裝mysql6初始化安裝密碼的方法

    這篇文章主要介紹了centos7下安裝mysql6初始化安裝密碼的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • mysql建表常用的sql語(yǔ)句匯總

    mysql建表常用的sql語(yǔ)句匯總

    這篇文章主要給大家介紹了mysql建表常用的sql語(yǔ)句,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 最全mysql數(shù)據(jù)類型梳理匯總

    最全mysql數(shù)據(jù)類型梳理匯總

    這篇文章主要介紹了最全mysql數(shù)據(jù)類型梳理匯總,??mysql??支持多種數(shù)據(jù)類型,主要有數(shù)值類型、日期與時(shí)間類型以及字符串類型,更多相關(guān)內(nèi)容需要的朋友可以參考一下
    2022-07-07
  • MySQL的安裝與配置詳細(xì)教程

    MySQL的安裝與配置詳細(xì)教程

    MySQL是一種關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),所使用的 SQL 語(yǔ)言是用于訪問(wèn)數(shù)據(jù)庫(kù)的最常用的,本文主要以Mysql免安裝版為例,幫助大家解決安裝與配置mysql的步驟
    2021-06-06
  • SQLyog的下載、安裝、破解、配置教程(MySQL可視化工具安裝)

    SQLyog的下載、安裝、破解、配置教程(MySQL可視化工具安裝)

    SQLyog是一款MySQL可視化工具,他可以將部分SQL操作通過(guò)圖形化界面操作來(lái)完成,方便開發(fā)者更好的進(jìn)行開發(fā)及數(shù)據(jù)庫(kù)設(shè)計(jì),這篇文章主要介紹了SQLyog的下載、安裝、破解、配置(MySQL可視化工具安裝),需要的朋友可以參考下
    2022-09-09

最新評(píng)論