Mysql索引
索引優(yōu)點
索引看著挺高大上的一個名字,說白了就是我們書最新面的目錄。
假如你用新華字典來查找“張”這個漢字,不使用目錄的話,你可能要從新華字典的第一頁找到最后一頁,可能要花二個小時。字典越厚呢,你花的時間就越多?,F(xiàn)在你使用目錄來查找“張”這個漢字,張的首字母是z,z開頭的漢字從900多頁開始,有了這條線索,你查找一個漢字可能只要一分鐘,由此可見索引的重要性。
索引用于快速找出在某個列中有一特定值的行。
不使用索引,MySQL必須從第1條記錄開始然后讀完整個表直到找出相關(guān)的行。表越大,花費的時間越多。如果表中查詢的列有一個索引,MySQL能快速到達(dá)一個位置去搜尋到數(shù)據(jù)文件的中間,沒有必要看所有數(shù)據(jù)。
當(dāng)然索引也不易過多,索引越多寫入,修改的速度越慢。因為,寫入修改數(shù)據(jù)時,也要修改索引。
MySQL的索引類型
索引類型 | 功能說明 |
---|---|
普通索引 | 最基本的索引,它沒有任何限制 |
唯一索引 | 某一行企用了唯一索引則不準(zhǔn)許這一列的行數(shù)據(jù)中有重復(fù)的值。針對這一列的每一行數(shù)據(jù)都要求是唯一的 |
主鍵索引 | 它是一種特殊的唯一索引,不允許有空值。一般是在建表的時候同時創(chuàng)建主鍵索引,常用于用戶ID。類似于書中的頁碼 |
全文索引 | 對于需要全局搜索的數(shù)據(jù),進(jìn)行全文索引 |
注意:以下部份請學(xué)習(xí)完12.7后再進(jìn)行學(xué)習(xí)。
普通索引
類型 | 詳細(xì)說明 |
---|---|
基本語法 | alter table 表 ?add index(字段) |
示例 | ALTER TABLE money ADD INDEX(username );money ADD INDEX(username ); |
示例解釋 | 為money表的username字段增加索引 |
唯一索引
類型 | 詳細(xì)說明 |
---|---|
基本語法 | alter table 表 add UNIQUE(字段) |
示例 | ALTER TABLE money ADD UNIQUE(email |
為money表的username字段增加索引 |
money
ADD UNIQUE(email
);????????示例解釋????為money表的email字段增加唯一索引????????全文索引
類型 | 詳細(xì)說明 |
---|---|
基本語法 | alter table 表 ?add FULLTEXT(字段) |
示例 | ALTER TABLE money ADD FULLTEXT(money ADD FULLTEXT(content ); |
示例解釋 | 為money表的content字段增加唯一索引 |
主鍵索引
類型 | 詳細(xì)說明 |
---|---|
基本語法 | alter table 表 add PRIMARY KEY(字段) |
示例 | ALTER TABLE money ADD PRIMARY KEY(id ); |
示例解釋 | 為money表的content字段增加唯一索引 |
主鍵索引
類型基本語法alter table 表 ?add PRIMARY KEY(字段)
詳細(xì)說明
為money表的id字段增加主鍵索引
test
(
id
INT NOT NULL ,
username
VARCHAR(20) NOT NULL ,
password
INT NOT NULL ,
content
示例id
ALTER TABLEmoney
ADD PRIMARY KEY(password
);username
content
示例解釋
test
(?? ? ? ??? INT NOT NULL , ?? ? ? ??? VARCHAR(20) NOT NULL , ?? ? ? ??? INT NOT NULL , ?? ? ? ??? INT NOT NULL , ??
? ? ?PRIMARY KEY (??), ??
? ? ?INDEX pw (??), ??
? ? ?UNIQUE (??),??
? ? ?FULLTEXT (??)??
?) ENGINE = InnoDB;??????