

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第七章,索引,項(xiàng)目知識(shí)要點(diǎn)與目標(biāo),索引及其應(yīng)用,索引 —— 是一種提高查找速度的機(jī)制,索引用來(lái)快速地尋找那些具有特定值的記錄,如果沒(méi)有索引,執(zhí)行查詢(xún)時(shí)MySQL必須從第一個(gè)記錄開(kāi)始掃描整個(gè)表的所有記錄,直至找到符合要求的記錄。表里面的記錄數(shù)量越多,這個(gè)操作的代價(jià)就越高。索引提供指針以指向存儲(chǔ)在表中指定列的數(shù)據(jù)值,然后根據(jù)指定的排序次序排列這些指針。數(shù)據(jù)庫(kù)使用索引的方式與使用書(shū)的目錄很相似:通過(guò)搜索索引找到特定的值,然后跟隨指針到達(dá)包含
2、該值的行。 如果作為搜索條件的列上已經(jīng)創(chuàng)建了索引,MySQL無(wú)需掃描任何記錄即可迅速得到目標(biāo)記錄所在的位置。如果表有1000個(gè)記錄,通過(guò)索引查找記錄至少要比順序掃描記錄快100倍。,索引文件,學(xué)生表student中建立“學(xué)號(hào)”索引(升序)示意圖,學(xué)生表 student,索引文件,,,,,,索引文件如何影響原表,,沒(méi)有索引文件時(shí):,,,,,指針在原表中順序移動(dòng),如果要找位于第10000條的學(xué)號(hào)”20070201”的記錄, 計(jì)算機(jī)要在表
3、中查找10000次,使用索引查找,有索引文件時(shí):(二分法查找實(shí)例) 計(jì)算機(jī)先在索引文件中學(xué)號(hào)為”20070201”的記錄,找到相應(yīng)的記錄號(hào),再到學(xué)生表中直接讀取相關(guān)記錄.,學(xué)生表 student,索引文件,,,索引文件如何加快查找速度,原因: (1)索引后,指針在索引文件中順序移動(dòng)。 (2)索引文件中記錄是有序的。 (3)有序后,可以用各種方法加快查詢(xún)速度, 如折半(二分)查找法,而排序前,只
4、 能順序查找記錄。,B樹(shù)索引示意圖,索引的分類(lèi),1. 普通索引(INDEX)這是最基本的索引類(lèi)型,它沒(méi)有唯一性之類(lèi)的限制。創(chuàng)建普通索引的關(guān)鍵字是INDEX。2. 唯一性索引(UNIQUE)這種索引和前面的普通索引基本相同,但有一個(gè)區(qū)別:索引列的所有值都只能出現(xiàn)一次,即必須是唯一的。創(chuàng)建唯一性索引的關(guān)鍵字是UNIQUE。3. 主鍵(PRIMARY KEY)主鍵是一種唯一性索引,它必須指定為“PRIMARY KE
5、Y”。主鍵一般在創(chuàng)建表的時(shí)候指定,也可以通過(guò)修改表的方式加入主鍵。但是每個(gè)表只能有一個(gè)主鍵。4. 全文索引(FULLTEXT)MySQL支持全文檢索和全文索引。全文索引的索引類(lèi)型為FULLTEXT。全文索引只能在VARCHAR或TEXT類(lèi)型的列上創(chuàng)建,并且只能在MyISAM表中創(chuàng)建。,,創(chuàng)建索引,1. 使用CREATE INDEX語(yǔ)句 使用CREATE INDEX語(yǔ)句可以在一個(gè)已有表上創(chuàng)建索引,一個(gè)表可以創(chuàng)建多個(gè)索引。語(yǔ)法格
6、式:CREATE [UNIQUE | FULLTEXT] INDEX 索引名ON 表名(列名[(長(zhǎng)度)] [ASC | DESC],...)說(shuō)明:●索引名:索引的名稱(chēng),索引名在一個(gè)表中名稱(chēng)必須是唯一的。● 列名:表示創(chuàng)建索引的列名。 長(zhǎng)度:表示使用列的前多少個(gè)字符創(chuàng)建索引。使用列的一部分創(chuàng)建索引可以使索引文件大大減小,從而節(jié)省磁盤(pán)空間。BLOB或TEXT列必須用前綴索引。● UNIQUE:UNIQUE表示創(chuàng)建的是唯一性索
7、引● FULLTEXT:FULLTEXT表示創(chuàng)建全文索引;● CREATE INDEX 語(yǔ)句并不能創(chuàng)建主鍵。,創(chuàng)建索引舉例,【例7.1】 根據(jù)Book表的書(shū)名列上的前6個(gè)字符建立一個(gè)升序索引name_book。 CREATE INDEX name_book ON Book(書(shū)名(6) ASC);可以在一個(gè)索引的定義中包含多個(gè)列,中間用逗號(hào)隔開(kāi),但是它們要屬于同一
8、個(gè)表。這樣的索引叫做復(fù)合索引?!纠?.2】 在Sell表的用戶(hù)號(hào)列和圖書(shū)編號(hào)列上建立一個(gè)復(fù)合索引sfz_bh_sell。 CREATE INDEX user_bh_sell ON Sell(用戶(hù)號(hào),圖書(shū)編號(hào));,ALTER TABLE語(yǔ)句創(chuàng)建索引,使用ALTER TABLE語(yǔ)句使用ALTER TABLE語(yǔ)句修改表,其中也包括向表中添加索引。語(yǔ)法格式如下: A
9、LTER TABLE 表名 ADD INDEX [索引名] (列名,...) /*添加索引*/ | ADD PRIMARY KEY [索引方式] (列名,...) /*添加主鍵*/ | ADD UNIQUE [索引名] (列名,...) /*添加唯一性索引*/ | ADD FULLTEXT [索引名] (列名,...) /*添加全文索引*/,ALTER TA
10、BLE創(chuàng)建索引舉例,【例7.3】 在Book表的書(shū)名列上創(chuàng)建一個(gè)普通索引。 ALTER TABLE Book ADD INDEX sm_book (書(shū)名);【例7.4】假設(shè)Book表中主鍵未設(shè)定,為Book表創(chuàng)建以圖書(shū)編號(hào)為主鍵索引,出版社和出版時(shí)間為復(fù)合索引,以加速表的檢索速度。 ALTER TABLE BookADD PRIMARY KEY(圖書(shū)編號(hào)),ADD INDEX mark(出版社,
11、出版時(shí)間); 這個(gè)例子中,既包括PRIMARY KEY,也包括復(fù)合索引,說(shuō)明MySQL可以同時(shí)創(chuàng)建多個(gè)索引。記住,使用PRIMARY KEY的列,必須是一個(gè)具有NOT NULL屬性的列。如果想要查看表中創(chuàng)建的索引的情況,可以使用SHOW INDEX FROM tbl_name語(yǔ)句,例如:SHOW INDEX FROM book;,創(chuàng)建表時(shí)創(chuàng)建索引,在前面兩種情況下,索引都是在表創(chuàng)建之后創(chuàng)建的。索引也可以在創(chuàng)建表時(shí)一起創(chuàng)建
12、。在創(chuàng)建表的CREATE TABLE語(yǔ)句中可以包含索引的定義。語(yǔ)法格式: CREATE TABLE 表名 ( 列名, ... | [索引項(xiàng)])其中,索引項(xiàng)語(yǔ)法格式如下: PRIMARY KEY (列名,...) /*主鍵*/ | {INDEX | KEY} [索引名] (列名,...) /*索引*/ | UNIQUE [INDEX] [索引名
13、] (列名,...) /*唯一性索引*/ | [FULLTEXT] [INDEX] [索引名] (列名,...) /*全文索引*/說(shuō)明:KEY通常是INDEX的同義詞。在定義列選項(xiàng)的時(shí)候,也可以將某列定義為PRIMARY KEY,但是當(dāng)主鍵是由多個(gè)列組成的多列索引時(shí),定義列時(shí)無(wú)法定義此主鍵,必須在語(yǔ)句最后加上一個(gè)PRIMARY KEY列名,…)子句。,【例7.5】 創(chuàng)建sell_copy表的語(yǔ)句如下,sell_c
14、opy表帶有身份證號(hào)和圖書(shū)編號(hào)的聯(lián)合主鍵,并在訂購(gòu)冊(cè)數(shù)列上創(chuàng)建索引。 CREATE TABLE sell_copy (身份證號(hào) CHAR(18) NOT NULL,圖書(shū)編號(hào) CHAR(20) NOT NULL,訂購(gòu)冊(cè)數(shù) INT(5),訂購(gòu)時(shí)間 DATETIME,PRIMARY KEY(身份證號(hào), 圖書(shū)編號(hào)),INDEX dgcs(訂購(gòu)冊(cè)數(shù)) );,創(chuàng)建表時(shí)創(chuàng)建索引舉例,刪除索引
15、,1. 使用DROP INDEX語(yǔ)句刪除索引語(yǔ)法格式: DROP INDEX索引名 ON 表名【例7.6】 刪除Book表上的sm_book索引。 DROP INDEX sm_book ON Book;,ALTER TABLE刪除索引,2. 使用ALTER TABLE語(yǔ)句刪除索引 語(yǔ)法格式: ALTER [IGNORE] TABLE 表名 |
16、DROP PRIMARY KEY /*刪除主鍵*/ | DROP INDEX 索引名 /*刪除索引*/【例7.7】 刪除Book表上的主鍵和mark索引。 ALTER TABLE BookDROP PRIMARY KEY,DROP INDEX mark; 如果從表中刪除了列,則索引可能會(huì)受到影響。如果所刪除的列為索引的組成部分,則該列也會(huì)從索引中刪除。如果組成索引的所
17、有列都被刪除,則整個(gè)索引將被刪除。,索引對(duì)查詢(xún)的影響,目前本書(shū)實(shí)例中所涉及的表最多只有幾十行的數(shù)據(jù),所以有沒(méi)有建立索引,還體會(huì)不到查詢(xún)速度上的差異,可是當(dāng)一個(gè)表里有成千上萬(wàn)行數(shù)據(jù)的時(shí)候,差異就非常明顯了?,F(xiàn)在假設(shè)有一個(gè)表,表里只有一列,由數(shù)值1~1000的1000行組成,現(xiàn)在要想查找到數(shù)字1000所在的行。如果沒(méi)有索引,要從第一行開(kāi)始匹配,若數(shù)值不是1000,則轉(zhuǎn)到下一行進(jìn)行匹配,這樣直到第1000行的時(shí)候才能找到數(shù)字1000所在行,也
18、就是說(shuō)服務(wù)器進(jìn)行了1000次的運(yùn)算。而當(dāng)在該列上創(chuàng)建一個(gè)索引后,則可以直接在索引值中找到1000的位置,然后找到1000所指向的行,在速度上比全表掃描至少快了100倍。當(dāng)執(zhí)行涉及多個(gè)表的連接查詢(xún)時(shí),索引將更有價(jià)值。,索引的弊端,首先,索引是以文件的形式存儲(chǔ)的,索引文件要占用磁盤(pán)空間。如果有大量的索引,索引文件可能會(huì)比數(shù)據(jù)文件更快地達(dá)到最大的文件尺寸。其次,在更新表中索引列上的數(shù)據(jù)時(shí),對(duì)索引也需要更新,這可能需要重新組織一個(gè)索引,如果
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
評(píng)論
0/150
提交評(píng)論