1.為什麼要用索引:
資料庫物件中的索引其實和書的目錄類似,主要是為了提高從表格中檢索資料的速度。由於資料儲存在資料庫表中,因此索引是建立在資料庫表物件上,由表中的一個欄位或多個欄位產生的鍵組成,這些鍵儲存在資料結構(B-樹或雜湊表)中,透過MySQL可以快速有效地尋找與鍵相關聯的欄位。根據索引的儲存類型,索引可以分為B型樹索引(BTREE)和雜湊索引(HASH)。注意:InnoDB和MyISAM儲存引擎支援BTREE類型索引,MEMORY儲存引擎支援HASH類型的索引,預設為前者索引。
MySQL支援6種索引,分別為普通索引、唯一索引、全文索引、單列索引、多列索引、空間索引。
以下情況適合建立索引:
1. 經常被查詢的欄位。即在WHERE子句中出現的欄位。
2. 在分組的字段,即在GROUP BY 子句中出現的字段。
3. 存在依賴關係的子表和父表之間的聯合查詢,即主鍵或外鍵欄位。
4. 設定唯一完整約束的欄位。
2.建立和檢視索引:
索引的操作包括建立索引、檢視索引、 刪除索引。所謂建立索引,就是在表的一個欄位或多個欄位上建立索引,在MySQL中,可以通常三種方式來建立索引,在建立表時建立索引、在已經存在的表上建立索引、透過SQL語句ALTER TABLE建立索引。
2.1 建立和檢視普通索引:
所謂普通索引就是在建立索引時,不附加任何限制條件(唯一、非空白等限制)。該類型的索引可以建立在任何類型的欄位上。
2.1.1 建立表格時建立普通索引:
文法格式如下:
CREATE TABLE table_name( 属性名 数据类型, 属性名 数据类型, ...... 属性名 数据类型, INDEX|KEY [索引名] (属性名1 [(长度)] [ASC|DESC]) );
說明:INDEX或KEY參數用來指定欄位為索引,「索引名」參數用來指定所建立索引的名稱,「屬性名1」參數用來指定索引所關聯的欄位的名稱,「長度」參數用來指定索引的長度,「ASC|DESC」參數用來指定升序還是降序。
注意:在建立索引時,可以指定索引的長度。這是因為不同儲存引擎定義了表格的最大索引數和最大索引長度。 MySQL所支援的儲存引擎對每個表至少支援16個索引,總索引長度至少256位元組。
範例:
CREATE TABLE t_dept( deptno INT, dname VARCHAR(30), loc VARCHAR(40), INDEX index_deptno (deptno) );
說明:
可以透過 SHOW CREATE TABLE t_dept G 查看是否成功建立了索引;
可以透過 EXPLAIN SELECT * FROM t_dept WHERE deptno=1G;來校驗資料庫表中索引是否被使用。如果執行結果中的possible_keys和key欄位處的值都為所建立的索引名稱index_deptno,則表示該索引已經存在,而且已經開始啟用。
2.1.2 在已經存在的表上建立普通索引:
透過SQL語句CREATE INDEX實現,其語法形式為:
CREATE INDEX 索引名
ON 表名 (屬性名 [(長度)] [ADC|DESC])
2.1.3 透過SQL語句ALTER TABLE 建立普通索引:
語法形式為:
ALTER TABLE table_name ADD INDEX|KEY 索引名 (屬性名稱 [(長度)] [ASC|DESC]);
2.2 建立並檢視唯一索引:
所謂唯一索引,就是在建立索引時,限制索引的值必須是唯一的。透過該類型的索引可以更快的查詢某筆記錄。在MySQL中,根據建立索引的方式,可以分為自動索引和手動索引兩種。
所謂自動索引,是指在資料庫表裡設定完整性約束時,該表會被系統自動建立索引。所謂手動索引,是指手動在表上建立索引。當設定表中的某個欄位為主鍵或唯一完整性限制時,系統就會自動建立關聯該欄位的唯一索引。
2.2.1 建立表格時建立唯一索引:
語法形式為:
CREATE TABLE table_name( 属性名 数据类型, 属性名 数据类型, ...... 属性名 数据类型, UNIQUE INDEX|KEY [索引名] (属性名1 [(长度)] [ASC | DESC]) );
說明:UNIQUE INDEX或UNIQUE KEY表示建立唯一索引。
2.2.2 在已經存在的表上建立唯一索引:
透過SQL語句CREATE UNIQUE INDEX來實現,語法形式為:
CREATE UNIQUE INDEX 索引名
ON 表名 (屬性名 [(長度)] [ASC|DESC]);
2.2.3 透過SQL語句ALTER TABLE建立唯一索引:
語法形式為:
ALTER TABLE table_name ADD UNIQUE INDEX|KEY 索引名 (屬性名稱 [(長度)] [ASC|DESC]);
2.3 创建和查看全文索引:
全文索引主要关联在数据类型为CHAR、VARCHAR和TEXT的字段上,以便能更加快速的查询数据量较大的字符串类型的字段。MySQL只能在存储引擎为MyISAM的数据库表上创建全文引擎。默认情况下,全文引擎的搜索执行方式为不区分大小写,如果全文引擎所关联的字段为二进制数据类型,则以区分大小写的方式执行。
2.3.1 创建表时创建全文索引:
语法形式为:
CREATE TABLE table_name ( 属性名 数据类型, 属性名 数据类型, ...... 属性名 数据类型, FULLTEXT INDEX|KEY [索引名] (属性名1 [(长度)] [ASC|DESC]) );
2.3.2 在已经存在的表上创建全文索引:
语法形式为:
CREATE FULLTEXT INDEX 索引名
ON 表名 (属性名 [(长度)] [ASC|DESC]);
2.3.3 通过SQL语句ALTER TABLE 创建全文索引:
语法形式为:
ALTER TABLE table_name
ADD FULLTEXT INDEX|KEY 索引名 (属性名 [(长度)] [ASC|DESC]);
2.4 创建和查看多列索引:
所谓多列索引,是指在创建索引时,所关联的字段不是一个字段,而是多个字段。虽然可以通过所关联的字段进行查询,但是只有查询条件中使用了所关联字段中的第一个字段,多列索引才会被使用。
2.4.1 创建表时创建多列索引:
语法形式如下:
CREATE TABLE table_name( 属性名 数据类型, 属性名 数据类型, ...... 属性名 数据类型, INDEX|KEY [索引名] (属性名1 [(长度)] [ASC|DESC]), ...... (属性名1 [(长度)] [ASC|DESC]) );
上述语句创建索引时,所关联的字段至少大于一个字段。
2.4.2 在已经存在的表上创建多列索引:
语法形式为:
CREATE INDEX 索引名 ON 表名 ( 属性名 [(长度)] [ASC|DESC], ...... 属性名n [(长度)] [ASC|DESC] );
2.4.3 通过SQL语句ALTRE TABLE 创建多列索引:
语法形式为:
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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。