1.為什么使用索引:?
??? 數(shù)據(jù)庫對象中的索引其實(shí)和書的目錄類似,主要是為了提高從表中檢索數(shù)據(jù)的速度。由于數(shù)據(jù)存儲在數(shù)據(jù)庫表中,所以索引是創(chuàng)建在數(shù)據(jù)庫表對象上,由表中的一個(gè)字段或者多個(gè)字段生成的鍵組成,這些鍵存儲在數(shù)據(jù)結(jié)構(gòu)(B-樹或者哈希表)中,通過mysql可以快速有效查找與鍵相關(guān)聯(lián)的字段。根據(jù)索引的存儲類型,可以將索引分為B型樹索引(BTREE)和哈希索引(HASH)。注意:InnoDB和MyISAM存儲引擎支持BTREE類型索引,MEMORY存儲引擎支持HASH類型的索引,默認(rèn)為前者索引。
??? MySQL支持6種索引,分別是普通索引、唯一索引、全文索引、單列索引、多列索引、空間索引。
??? 以下情況適合創(chuàng)建索引:
??? 1. 經(jīng)常被查詢的字段。即在WHERE子句中出現(xiàn)的字段。
??? 2. 在分組的字段,即在GROUP BY 子句中出現(xiàn)的字段。
??? 3. 存在依賴關(guān)系的子表和父表之間的聯(lián)合查詢,即主鍵或外鍵字段。
??? 4. 設(shè)置唯一完整約束的字段。
2.創(chuàng)建和查看索引:?
??? 索引的操作包括創(chuàng)建索引、查看索引、 刪除索引。所謂創(chuàng)建索引,就是在表的一個(gè)字段或多個(gè)字段上建立索引,在MySQL中,可以通常三種方式來創(chuàng)建索引,創(chuàng)建表時(shí)創(chuàng)建索引、在已經(jīng)存在的表上創(chuàng)建索引、通過SQL語句ALTER TABLE創(chuàng)建索引。?
2.1 創(chuàng)建和查看普通索引:?
??? 所謂普通索引就是在創(chuàng)建索引時(shí),不附加任何限制條件(唯一、非空等限制)。該類型的索引可以創(chuàng)建在任何類型的字段上。?
2.1.1 創(chuàng)建表時(shí)創(chuàng)建普通索引:
語法格式如下:
CREATE TABLE table_name( 屬性名 數(shù)據(jù)類型, 屬性名 數(shù)據(jù)類型, ...... 屬性名 數(shù)據(jù)類型, INDEX|KEY [索引名] (屬性名1 [(長度)] [ASC|DESC]) );
?? 說明:INDEX或者KEY參數(shù)用來指定字段為索引,“索引名”參數(shù)用來指定所創(chuàng)建索引的名稱,“屬性名1”參數(shù)用來指定索引所關(guān)聯(lián)的字段的名稱,“長度”參數(shù)用來指定索引的長度,“ASC|DESC”參數(shù)用來指定升序還是降序。
?? 注意:在創(chuàng)建索引時(shí),可以指定索引的長度。這是因?yàn)椴煌鎯σ娑x了表的最大索引數(shù)和最大索引長度。MySQL所支持的存儲引擎對每個(gè)表至少支持16個(gè)索引,總索引長度至少256字節(jié)。
示例:
CREATE TABLE t_dept( deptno INT, dname VARCHAR(30), loc VARCHAR(40), INDEX index_deptno (deptno) );
說明:
?? 可以通過 SHOW CREATE TABLE t_dept G 來查看是否成功創(chuàng)建了索引;
?? 可以通過 EXPLAIN SELECT * FROM t_dept WHERE deptno=1G;來校驗(yàn)數(shù)據(jù)庫表中索引是否被使用。如果執(zhí)行結(jié)果中的possible_keys和key字段處的值都為所創(chuàng)建的索引名index_deptno,則說明該索引已經(jīng)存在,而且已經(jīng)開始啟用。
2.1.2 在已經(jīng)存在的表上創(chuàng)建普通索引:
通過SQL語句CREATE INDEX實(shí)現(xiàn),其語法形式為:
CREATE INDEX 索引名
??? ON 表名 (屬性名? [(長度)]? [ADC|DESC])
2.1.3 通過SQL語句ALTER TABLE 創(chuàng)建普通索引:
語法形式為:
ALTER TABLE table_name ADD INDEX|KEY 索引名 (屬性名 [(長度)] [ASC|DESC]);
2.2 創(chuàng)建和查看唯一索引:?
??? 所謂唯一索引,就是在創(chuàng)建索引時(shí),限制索引的值必須是唯一的。通過該類型的索引可以更快的查詢某條記錄。在MySQL中,根據(jù)創(chuàng)建索引的方式,可以分為自動(dòng)索引和手動(dòng)索引兩種。
??? 所謂自動(dòng)索引,是指在數(shù)據(jù)庫表里設(shè)置完整性約束時(shí),該表會被系統(tǒng)自動(dòng)創(chuàng)建索引。所謂手動(dòng)索引,是指手動(dòng)在表上創(chuàng)建索引。當(dāng)設(shè)置表中的某個(gè)字段為主鍵或唯一完整性約束時(shí),系統(tǒng)就會自動(dòng)創(chuàng)建關(guān)聯(lián)該字段的唯一索引。?
2.2.1 創(chuàng)建表時(shí)創(chuàng)建唯一索引:
語法形式為:
CREATE TABLE table_name( 屬性名 數(shù)據(jù)類型, 屬性名 數(shù)據(jù)類型, ...... 屬性名 數(shù)據(jù)類型, UNIQUE INDEX|KEY [索引名] (屬性名1 [(長度)] [ASC | DESC]) );
說明:UNIQUE INDEX或者UNIQUE KEY表示創(chuàng)建唯一索引。
2.2.2 在已經(jīng)存在的表上創(chuàng)建唯一索引:
通過SQL語句CREATE UNIQUE INDEX來實(shí)現(xiàn),語法形式為:
CREATE UNIQUE INDEX 索引名
??? ON 表名 (屬性名 [(長度)] [ASC|DESC]);
2.2.3 通過SQL語句ALTER TABLE創(chuàng)建唯一索引:
語法形式為:
ALTER TABLE table_name ADD UNIQUE INDEX|KEY 索引名 (屬性名 [(長度)] [ASC|DESC]);
2.3 創(chuàng)建和查看全文索引:?
??? 全文索引主要關(guān)聯(lián)在數(shù)據(jù)類型為CHAR、VARCHAR和TEXT的字段上,以便能更加快速的查詢數(shù)據(jù)量較大的字符串類型的字段。MySQL只能在存儲引擎為MyISAM的數(shù)據(jù)庫表上創(chuàng)建全文引擎。默認(rèn)情況下,全文引擎的搜索執(zhí)行方式為不區(qū)分大小寫,如果全文引擎所關(guān)聯(lián)的字段為二進(jìn)制數(shù)據(jù)類型,則以區(qū)分大小寫的方式執(zhí)行。?
2.3.1 創(chuàng)建表時(shí)創(chuàng)建全文索引:
語法形式為:
CREATE TABLE table_name ( 屬性名 數(shù)據(jù)類型, 屬性名 數(shù)據(jù)類型, ...... 屬性名 數(shù)據(jù)類型, FULLTEXT INDEX|KEY [索引名] (屬性名1 [(長度)] [ASC|DESC]) );
2.3.2 在已經(jīng)存在的表上創(chuàng)建全文索引:
語法形式為:
CREATE FULLTEXT INDEX 索引名
??? ON 表名 (屬性名 [(長度)] [ASC|DESC]);
2.3.3 通過SQL語句ALTER TABLE 創(chuàng)建全文索引:
語法形式為:
ALTER TABLE table_name
??? ADD FULLTEXT INDEX|KEY 索引名 (屬性名 [(長度)] [ASC|DESC]);
2.4 創(chuàng)建和查看多列索引:?
??? 所謂多列索引,是指在創(chuàng)建索引時(shí),所關(guān)聯(lián)的字段不是一個(gè)字段,而是多個(gè)字段。雖然可以通過所關(guān)聯(lián)的字段進(jìn)行查詢,但是只有查詢條件中使用了所關(guān)聯(lián)字段中的第一個(gè)字段,多列索引才會被使用。?
2.4.1 創(chuàng)建表時(shí)創(chuàng)建多列索引:
語法形式如下:
CREATE TABLE table_name( 屬性名 數(shù)據(jù)類型, 屬性名 數(shù)據(jù)類型, ...... 屬性名 數(shù)據(jù)類型, INDEX|KEY [索引名] (屬性名1 [(長度)] [ASC|DESC]), ...... (屬性名1 [(長度)] [ASC|DESC]) );
上述語句創(chuàng)建索引時(shí),所關(guān)聯(lián)的字段至少大于一個(gè)字段。
2.4.2 在已經(jīng)存在的表上創(chuàng)建多列索引:
語法形式為:
CREATE INDEX 索引名 ON 表名 ( 屬性名 [(長度)] [ASC|DESC], ...... 屬性名n [(長度)] [ASC|DESC] );
2.4.3 通過SQL語句ALTRE TABLE 創(chuàng)建多列索引:
語法形式為:
ALTER TABLE table_name ADD INDEX|KEY 索引名(屬性名 [(長度)] [ASC|DESC],屬性名n [(長度)] [ASC|DESC]);
3. 刪除索引:
刪除索引的語法形式:
DROP INDEX index_name ON table_name
4. 查看索引:
查看索引的語法形式:
SHOW INDEX FROM table_name
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持。