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); ALTER TABLE table_name ADD FULLTEXT (column_list);
其中table_name是要增長索引名的表名,column_list指出對哪些列列進行索引,多列時各列之間使用半角逗號隔開。索引名index_name是可選的,若是不指定索引名稱,MySQL將根據第一個索引列自動指定索引名稱,另外,ALTER TABLE容許在單個語句中更改多個表,所以能夠在同時建立多個索引。mysql
CREATE INDEX index_name ON table_name (column_list); CREATE UNIQUE index_name ON table_name (column_list); CREATE FULLTEXT index_name ON table_name (column_list);
table_name、index_name和column_list具備與ALTER TABLE語句中相同的含義,索引名必須指定。另外,不能用CREATE INDEX語句建立PRIMARY KEY索引。sql
ALTER TABLE article ADD FULLTEXT ('title', 'content'); 在進行檢索時就須要使用以下的語法進行檢索: SELECT * FROM article WHERE MATCH('title', 'content') AGAINST ('查詢字符串');
where a=3 and b=45 and c=5 .... #這種三個索引順序使用中間沒有斷點,所有發揮做用; where a=3 and c=5... #這種狀況下b就是斷點,a發揮了效果,c沒有效果 where b=3 and c=4... #這種狀況下a就是斷點,在a後面的索引都沒有發揮做用,這種寫法聯合索引沒有發揮任何效果; where b=45 and a=3 and c=5 .... #這個跟第一個同樣,所有發揮做用,abc只要用上了就行,跟寫的順序無關
(a,b,c) 三個列上加了聯合索引(是聯合索引 不是在每一個列上單獨加索引)而是創建了a,(a,b),(a,b,c)三個索引,另外(a,b,c)多列索引和 (a,c,b)是不同的。
具體實例能夠說明:數據庫
(0) select * from mytable where a=3 and b=5 and c=4; #abc三個索引都在where條件裏面用到了,並且都發揮了做用 (1) select * from mytable where c=4 and b=6 and a=3; #這條語句爲了說明 組合索引與在SQL中的位置前後無關,where裏面的條件順序在查詢以前會被mysql自動優化,效果跟上一句同樣 (2) select * from mytable where a=3 and c=7; #a用到索引,b沒有用,因此c是沒有用到索引效果的 (3) select * from mytable where a=3 and b>7 and c=3; #a用到了,b也用到了,c沒有用到,這個地方b是範圍值,也算斷點,只不過自身用到了索引 (4) select * from mytable where b=3 and c=4; #由於a索引沒有使用,因此這裏 bc都沒有用上索引效果 (5) select * from mytable where a>4 and b=7 and c=9; #a用到了 b沒有使用,c沒有使用 (6) select * from mytable where a=3 order by b; #a用到了索引,b在結果排序中也用到了索引的效果,前面說了,a下面任意一段的b是排好序的 (7) select * from mytable where a=3 order by c; #a用到了索引,可是這個地方c沒有發揮排序效果,由於中間斷點了,使用 explain 能夠看到 filesort (8) select * from mytable where b=3 order by a; #b沒有用到索引,排序中a也沒有發揮索引效果
注意:在查詢時,MYSQL只能使用一個索引,若是創建的是多個單列的普通索引,在查詢時會根據查詢的索引字段,dom
從中選擇一個限制最嚴格的單例索引進行查詢。別的索引都不會生效。函數
不能使用索引的狀況 優化
SELECT * FROM tab_name WHERE index_column LIKE 'abc%'; #索引是有效的 SELECT * FROM tab_name WHERE index_column LIKE '%abc'; #索引是無效的SELECT * FROM tab_name WHERE index_column LIKE '%abc%'; #索引是無效的
當檢索的字段內容比較大並且檢索內容先後部分都不肯定的狀況下,能夠改成全文索引,並使用特定的檢索方式。spa
基於REVERSE()函數來建立一個函數索引。code
一、準備數據:orm
CREATE TABLE jka AS SELECT ROWNUM id, dbms_random.string('x',10) v FROM dual CONNECT BY LEVEL <= 10000;
二、建立原始索引:blog
CREATE INDEX jka_normal ON jka (v);
三、如下SQL基於jka_normal索引走範圍掃描:
SELECT * FROM jka WHERE v LIKE 'ABC%';
四、可是下面的SQL將走全表掃描(不會使用索引):
SELECT * FROM jka WHERE v LIKE '%ABC';
五、如今,建立一個函數索引(不要與反向索引[REVERSE INDEX]混淆):
CREATE INDEX jka_reverse ON jka(REVERSE(v));
六、下面的SQL將基於jka_reverse索引走範圍掃描:
SELECT * FROM jka WHERE REVERSE(v) LIKE REVERSE('%ABC');