序言

         之前寫到MySQL對表的增刪改查(查詢最為重要)后,就感覺MySQL就差不多學(xué)完了,沒有想繼續(xù)學(xué)下去的心態(tài)了,原因可能是由于別人的影響,覺得對于MySQL來說,知道了一些復(fù)雜的查詢,就夠了,但是我認(rèn)為,不管有沒有用,現(xiàn)在學(xué)著不懂的東西,說明就是自己薄弱的地方,多學(xué)才能比別人更強(qiáng)

                                        --WH

 

一、什么是索引?為什么要建立索引?

       索引用于快速找出在某個列中有一特定值的行,不使用索引,MySQL必須從第一條記錄開始讀完整個表,直到找出相關(guān)的行,表越大,查詢數(shù)據(jù)所花費的時間就越多,如果表中查詢的列有一個索引,MySQL能夠快速到達(dá)一個位置去搜索數(shù)據(jù)文件,而不必查看所有數(shù)據(jù),那么將會節(jié)省很大一部分時間。

       例如:有一張person表,其中有2W條記錄,記錄著2W個人的信息。有一個Phone的字段記錄每個人的電話號碼,現(xiàn)在想要查詢出電話號碼為xxxx的人的信息。

          如果沒有索引,那么將從表中第一條記錄一條條往下遍歷,直到找到該條信息為止。

          如果有了索引,那么會將該P(yáng)hone字段,通過一定的方法進(jìn)行存儲,好讓查詢該字段上的信息時,能夠快速找到對應(yīng)的數(shù)據(jù),而不必在遍歷2W條數(shù)據(jù)了。其中MySQL中的索引的存儲類型有兩種:BTREE、HASH。 也就是用樹或者Hash值來存儲該字段,要知道其中詳細(xì)是如何查找的,就需要會算法的知識了。我們現(xiàn)在只需要知道索引的作用,功能是什么就行。

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運,軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式