序言
之前寫到MySQL對表的增刪改查(查詢最為重要)后,就感覺MySQL就差不多學(xué)完了,沒有想繼續(xù)學(xué)下去的心態(tài)了,原因可能是由于別人的影響,覺得對于MySQL來說,知道了一些復(fù)雜的查詢,就夠了,但是我認(rèn)為,不管有沒有用,現(xiàn)在學(xué)著不懂的東西,說明就是自己薄弱的地方,多學(xué)才能比別人更強(qiáng)
--WH
一、什么是索引?為什么要建立索引?
索引用于快速找出在某個(gè)列中有一特定值的行,不使用索引,MySQL必須從第一條記錄開始讀完整個(gè)表,直到找出相關(guān)的行,表越大,查詢數(shù)據(jù)所花費(fèi)的時(shí)間就越多,如果表中查詢的列有一個(gè)索引,MySQL能夠快速到達(dá)一個(gè)位置去搜索數(shù)據(jù)文件,而不必查看所有數(shù)據(jù),那么將會(huì)節(jié)省很大一部分時(shí)間。
例如:有一張person表,其中有2W條記錄,記錄著2W個(gè)人的信息。有一個(gè)Phone的字段記錄每個(gè)人的電話號碼,現(xiàn)在想要查詢出電話號碼為xxxx的人的信息。
如果沒有索引,那么將從表中第一條記錄一條條往下遍歷,直到找到該條信息為止。
如果有了索引,那么會(huì)將該P(yáng)hone字段,通過一定的方法進(jìn)行存儲(chǔ),好讓查詢該字段上的信息時(shí),能夠快速找到對應(yīng)的數(shù)據(jù),而不必在遍歷2W條數(shù)據(jù)了。其中MySQL中的索引的存儲(chǔ)類型有兩種:BTREE、HASH。 也就是用樹或者Hash值來存儲(chǔ)該字段,要知道其中詳細(xì)是如何查找的,就需要會(huì)算法的知識了。我們現(xiàn)在只需要知道索引的作用,功能是什么就行。