InnoDB按照主鍵進(jìn)行聚集,如果沒有定義主鍵,InnoDB會(huì)試著使用唯一的非空索引來代替。如果沒有這種索引,InnoDB就會(huì)定義隱藏的主鍵然后在上面進(jìn)行聚集。
創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站制作、做網(wǎng)站與策劃設(shè)計(jì),耒陽(yáng)網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)10余年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:耒陽(yáng)等地區(qū)。耒陽(yáng)做網(wǎng)站價(jià)格咨詢:18982081108
所以,對(duì)于 聚集索引 來說,你創(chuàng)建主鍵的時(shí)候,自動(dòng)就創(chuàng)建了主鍵的聚集索引。
而普通索引(非聚集索引)的語法,大多數(shù)數(shù)據(jù)庫(kù)都是通用的:
CREATE INDEX Syntax
CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name
[index_type]
ON tbl_name (index_col_name,...)
[index_type]
index_col_name:
col_name [(length)] [ASC | DESC]
index_type:
USING {BTREE | HASH | RTREE}
[java] view plaincopy
-- 創(chuàng)建無索引的表格
create table testNoPK (
id int not null,
name varchar(10)
);
-- 創(chuàng)建普通索引
create index IDX_testNoPK_Name on testNoPK (name);
mysql的聚簇索引是指innodb引擎的特性,mysiam并沒有,如果需要該索引,只要將索引指定為主鍵(primary key)就可以了。
比如:
1
2
3
4
5
6
7
8
create table blog_user
(
user_Name char(15) not null check(user_Name !=''),
user_Password char(15) not null,
user_emial varchar(20) not null unique,
primary key(user_Name)
)engine=innodb default charset=utf8 auto_increment=1;
其中的 primary key(user_Name) 這個(gè)就是聚簇索引索引了;
索引用于快速找到特定一些值的記錄。如果沒有索引,MySQL就必須從第一行記錄開始讀取整個(gè)表來檢索記錄。表越大,資源消耗越大。如果在字段上有索引的話,MySQL就能很快決定該從數(shù)據(jù)文件的哪個(gè)位置開始搜索記錄,而無須查找所有的數(shù)據(jù)。如果表中有1000條記錄的話,那么這至少比順序地讀取數(shù)據(jù)快100倍。注意,如果需要存取幾乎全部1000條記錄的話,那么順序讀取就更快了,因?yàn)檫@樣會(huì)使磁盤搜索最少。
大部分MySQL索引(PRIMARY KEY, UNIQUE,INDEX 和 FULLTEXT)都是以B樹方式存儲(chǔ)。只有空間類型的字段使用R樹存儲(chǔ),MEMORY (HEAP)表支持哈希索引。
字符串默認(rèn)都是自動(dòng)壓縮前綴和后綴中的空格。
通常,如下所述幾種情況下可以使用索引。哈希索引(用于 MEMORY 表)的獨(dú)特之處在后面會(huì)討論到。
想要盡快找到匹配 WHERE 子句的記錄。
根據(jù)條件排除記錄。如果有多個(gè)索引可共選擇的話,MySQL通常選擇能找到最少記錄的那個(gè)索引。
做表連接查詢時(shí)從其他表中檢索記錄。
想要在指定的索引字段 key_col 上找到它的 MIN() 或 MAX() 值。優(yōu)化程序會(huì)在檢查索引的
key_col 字段前就先檢查其他索引部分是否使用了 WHERE key_part_# = constant 子句。這樣的話,
MySQL會(huì)為 MIN() 或 MAX() 表達(dá)式分別單獨(dú)做一次索引查找,并且將它替換成常數(shù)。當(dāng)所有的表達(dá)式都被替換成常數(shù)后,查詢就立刻返回。如下:
SELECT MIN(key_part2),MAX(key_part2) FROM tbl_name WHERE key_part1=10;
對(duì)表作排序或分組,當(dāng)在一個(gè)可用的最左前綴索引上做分組或排序時(shí)(如 ORDER
BY key_part1, key_part2)。如果所有的索引部分都按照 DESC 排序,索引就按倒序排序。
有些時(shí)候,查詢可以優(yōu)化使得無需計(jì)算數(shù)據(jù)就能直接取得結(jié)果。當(dāng)查詢使用表中的一個(gè)數(shù)字型字段,且這個(gè)字段是索引的最左部分,則可能從索引樹中能很快就取得結(jié)果:
SELECTkey_part3FROMtbl_nameWHEREkey_part1=1
假設(shè)有如下 SELECT 語句:
如果在 col1 和 col2 上有一個(gè)多字段索引的話,就能直接取得對(duì)應(yīng)的記錄了。
CREATE [UNIQUE] INDEX index_name ON table_name(字段 [ASC|DESC]);
UNIQUE --確保所有的索引列中的值都是可以區(qū)分的。
[ASC|DESC] --在列上按指定排序創(chuàng)建索引。
(創(chuàng)建索引的準(zhǔn)則:
1.如果表里有幾百行記錄則可以對(duì)其創(chuàng)建索引(表里的記錄行數(shù)越多索引的效果就越明顯)。
2.不要試圖對(duì)表創(chuàng)建兩個(gè)或三個(gè)以上的索引。
3.為頻繁使用的行創(chuàng)建索引。
)
示例
create index i_1 on emp(empno asc);
MySql為以下這些操作使用索引:
1、為了快速查找匹配WHERE條件的行。
2、為了從考慮的條件中消除行。如果在多個(gè)索引之間選擇一個(gè),正常情況下,MySql使用找到行的最小數(shù)量的那個(gè)索引。
3、如果表有一個(gè)multiple-column索引,任何一個(gè)索引的最左前綴可以通過使用優(yōu)化器來查找行。例如,如果你有一個(gè) three-column索引在(col1, col2, col3),你能搜索索引在(col1), (col1, col2),和 (col1, col2, col3)。