2.MySQL索引的原理(TODO)
3.MySQL索引的創(chuàng)建時(shí)機(jī)(TODO)MySQL的索引有原理會(huì)在下一篇文章里給出詳細(xì)的闡述,現(xiàn)在只描述一下索引的使用。
1.查看索引
如下面的代碼所示,
1:row 中Key_name:PRIMARY 主鍵索引
1,2:row為組合索引
mysql> show index from table_name;
mysql> show keys from table_name;
*************************** 1. row ***************************
Table: table_name
Non_unique: 0
Key_name: PRIMARY
Seq_in_index: 1
Column_name: id
Collation: A
Cardinality: 7533
Sub_part: NULL
Packed: NULL
Null:
Index_type: BTREE
Comment:
Index_comment:
*************************** 2. row ***************************
Table: table_name
Non_unique: 0
Key_name: domain
Seq_in_index: 1
Column_name: domain_id
Collation: A
Cardinality: 2
Sub_part: NULL
Packed: NULL
Null: YES
Index_type: BTREE
Comment:
Index_comment:
*************************** 3. row ***************************
Table: table_name
Non_unique: 0
Key_name: domain
Seq_in_index: 2
Column_name: domain
Collation: A
Cardinality: 7533
Sub_part: NULL
Packed: NULL
Null: YES
Index_type: BTREE
Comment:
Index_comment:
3 rows in set (0.00 sec)
· Non_unique 如果索引不能包括重復(fù)詞,則為0。如果可以,則為1。
· Key_name 索引的名稱。
· Seq_in_index 索引中的列序列號(hào),從1開始。
· Column_name 列名稱。
· Collation 列以什么方式存儲(chǔ)在索引中。在MySQL中,有值‘A’(升序)或NULL(無(wú)分類)。
· Cardinality 索引中唯一值的數(shù)目的估計(jì)值。通過(guò)運(yùn)行ANALYZE TABLE或myisamchk -a可以更新。基數(shù)根據(jù)被存儲(chǔ)為整數(shù)的統(tǒng)計(jì)數(shù)據(jù)來(lái)計(jì)數(shù),所以即使對(duì)于小型表,該值也沒(méi)有必要是精確的。基數(shù)越大,當(dāng)進(jìn)行聯(lián)合時(shí),MySQL使用該索引的機(jī) 會(huì)就越大。
· Sub_part 如果列只是被部分地編入索引,則為被編入索引的字符的數(shù)目。如果整列被編入索引,則為NULL。
· Packed 指示關(guān)鍵字如何被壓縮。如果沒(méi)有被壓縮,則為NULL。
· Null 如果列含有NULL,則含有YES。如果沒(méi)有,則該列含有NO。
· Index_type 用過(guò)的索引方法(BTREE, FULLTEXT, HASH, RTREE)。
· Comment
2 創(chuàng)建索引
CREATE INDEX和ALTER TABLE兩種方式
ALTER TABLE table_name ADD INDEX index_name (column_list) #增加普通索引
ALTER TABLE table_name ADD UNIQUE (column_list) #增加唯一索引
ALTER TABLE table_name ADD PRIMARY KEY (column_list) #增加主鍵索引
table_name是要增加索引的表名:
column_list要索引的列名,多列時(shí)各列之間用逗號(hào)分隔。
index_name:索引名,可選,缺省時(shí),MySQL將根據(jù)第一個(gè)索引列賦一個(gè)名稱。
CREATE INDEX 增加普通索引、UNIQUE索引
CREATE INDEX index_name ON table_name (column_list)
CREATE UNIQUE INDEX index_name ON table_name (column_list)
Create INDEX不能創(chuàng)建PRIMARY KEY索引
添加索引時(shí)
CREATE INDEX index_name ON table_name(name(length))可限制長(zhǎng)度。如果是CHAR,VARCHAR類型,length可以小于字段實(shí)際長(zhǎng)度;如果是BLOB和TEXT類型,必須指定 length。
主鍵:(不重復(fù)):應(yīng)該添加主鍵索引 PRIMARY KEY。一個(gè)表只能有一個(gè)主鍵。一種特殊的唯一索引,不允許有空值
唯一: 應(yīng)該添加UNIQUE索引,可以是單列不重復(fù)和多列不重復(fù)。組合唯一索引,多列不重復(fù)要保證組合不重復(fù)。索引列的值必須唯一,但允許有空值。
普通索引:添加索引可提高檢索的速度。
同一表中索引名稱不能重復(fù)。
3.刪除索引
ALTER TABLE或DROP INDEX刪除索引
DROP INDEX index_name ON talbe_name
ALTER TABLE table_name DROP INDEX index_name
ALTER TABLE table_name DROP PRIMARY KEY
最后一名是刪除主鍵。
對(duì)于組合索引,如從表中刪除了某列,則索引會(huì)受到影響。則該列也會(huì)從索引中刪除。如果刪除組成索引的所有列,則整個(gè)索引將被刪除。