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