婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 數據庫為何要建立索引的原因說明

數據庫為何要建立索引的原因說明

熱門標簽:漯河電銷回撥外呼系統 怎么修改高德地圖標注 西安電話自動外呼系統 合肥crm外呼系統加盟 城市地圖標志怎么標注 硅基電話機器人官網 長沙外呼系統平臺 美國地圖標注軟件下載 電話機器人怎么看余額
這里想把之前的索引學習筆記總結一下:

    首先明白為什么索引會增加速度,DB在執行一條Sql語句的時候,默認的方式是根據搜索條件進行全表掃描,遇到匹配條件的就加入搜索結果集合。如果我們對某一字段增加索引,查詢時就會先去索引列表中一次定位到特定值的行數,大大減少遍歷匹配的行數,所以能明顯增加查詢的速度。那么在任何時候都應該加索引么?這里有幾個反例:1、如果每次都需要取到所有表記錄,無論如何都必須進行全表掃描了,那么是否加索引也沒有意義了。2、對非唯一的字段,例如“性別”這種大量重復值的字段,增加索引也沒有什么意義。3、對于記錄比較少的表,增加索引不會帶來速度的優化反而浪費了存儲空間,因為索引是需要存儲空間的,而且有個致命缺點是對于update/insert/delete的每次執行,字段的索引都必須重新計算更新。

    那么在什么時候適合加上索引呢?我們看一個Mysql手冊中舉的例子,這里有一條sql語句:

    SELECT c.companyID, c.companyName FROM Companies c, User u WHERE c.companyID = u.fk_companyID AND c.numEmployees >= 0 AND c.companyName LIKE '%i%' AND u.groupID IN (SELECT g.groupID FROM Groups g WHERE g.groupLabel = 'Executive')

    這條語句涉及3個表的聯接,并且包括了許多搜索條件比如大小比較,Like匹配等。在沒有索引的情況下Mysql需要執行的掃描行數是 77721876行。而我們通過在companyID和groupLabel兩個字段上加上索引之后,掃描的行數只需要134行。在Mysql中可以通過 Explain Select來查看掃描次數。可以看出來在這種聯表和復雜搜索條件的情況下,索引帶來的性能提升遠比它所占據的磁盤空間要重要得多。

    那么索引是如何實現的呢?大多數DB廠商實現索引都是基于一種數據結構——B樹。因為B樹的特點就是適合在磁盤等直接存儲設備上組織動態查找表。B樹的定義是這樣的:一棵m(m>=3)階的B樹是滿足下列條件的m叉樹:

    1、每個結點包括如下作用域(j, p0, k1, p1, k2, p2, ... ki, pi) 其中j是關鍵字個數,p是孩子指針

    2、所有葉子結點在同一層上,層數等于樹高h

    3、每個非根結點包含的關鍵字個數滿足[m/2-1]=j=m-1

    4、若樹非空,則根至少有1個關鍵字,若根非葉子,則至少有2棵子樹,至多有m棵子樹

    看一個B樹的例子,針對26個英文字母的B樹可以這樣構造:

    可以看到在這棵B樹搜索英文字母復雜度只為o(m),在數據量比較大的情況下,這樣的結構可以大大增加查詢速度。然而有另外一種數據結構查詢的虛度比B樹更快——散列表。Hash表的定義是這樣的:設所有可能出現的關鍵字集合為u,實際發生存儲的關鍵字記為k,而|k|比|u|小很多。散列方法是通過散列函數h將u映射到表T[0,m-1]的下標上,這樣u中的關鍵字為變量,以h為函數運算結果即為相應結點的存儲地址。從而達到可以在o(1)的時間內完成查找。
    然而散列表有一個缺陷,那就是散列沖突,即兩個關鍵字通過散列函數計算出了相同的結果。設m和n分別表示散列表的長度和填滿的結點數,n/m為散列表的填裝因子,因子越大,表示散列沖突的機會越大。
    因為有這樣的缺陷,所以數據庫不會使用散列表來做為索引的默認實現,Mysql宣稱會根據執行查詢格式嘗試將基于磁盤的B樹索引轉變為和合適的散列索引以追求進一步提高搜索速度。我想其它數據庫廠商也會有類似的策略,畢竟在數據庫戰場上,搜索速度和管理安全一樣是非常重要的競爭點。


基本概念介紹:


索引

使用索引可快速訪問數據庫表中的特定信息。索引是對數據庫表中一列或多列的值進行排序的一種結構,例如 employee 表的姓(lname)列。如果要按姓查找特定職員,與必須搜索表中的所有行相比,索引會幫助您更快地獲得該信息。

索引提供指向存儲在表的指定列中的數據值的指針,然后根據您指定的排序順序對這些指針排序。數據庫使用索引的方式與您使用書籍中的索引的方式很相似:它搜索索引以找到特定值,然后順指針找到包含該值的行。

在數據庫關系圖中,您可以在選定表的“索引/鍵”屬性頁中創建、編輯或刪除每個索引類型。當保存索引所附加到的表,或保存該表所在的關系圖時,索引將保存在數據庫中。有關詳細信息,請參見創建索引。

注意;并非所有的數據庫都以相同的方式使用索引。有關更多信息,請參見數據庫服務器注意事項,或者查閱數據庫文檔。

作為通用規則,只有當經常查詢索引列中的數據時,才需要在表上創建索引。索引占用磁盤空間,并且降低添加、刪除和更新行的速度。在多數情況下,索引用于數據檢索的速度優勢大大超過它的。

索引列

可以基于數據庫表中的單列或多列創建索引。多列索引使您可以區分其中一列可能有相同值的行。

如果經常同時搜索兩列或多列或按兩列或多列排序時,索引也很有幫助。例如,如果經常在同一查詢中為姓和名兩列設置判據,那么在這兩列上創建多列索引將很有意義。

確定索引的有效性:

  • 檢查查詢的 WHERE 和 JOIN 子句。在任一子句中包括的每一列都是索引可以選擇的對象。
  • 對新索引進行試驗以檢查它對運行查詢性能的影響。
  • 考慮已在表上創建的索引數量。最好避免在單個表上有很多索引。
  • 檢查已在表上創建的索引的定義。最好避免包含共享列的重疊索引。
  • 檢查某列中唯一數據值的數量,并將該數量與表中的行數進行比較。比較的結果就是該列的可選擇性,這有助于確定該列是否適合建立索引,如果適合,確定索引的類型。
索引類型

根據數據庫的功能,可以在數據庫設計器中創建三種索引:唯一索引、主鍵索引和聚集索引。有關數據庫所支持的索引功能的詳細信息,請參見數據庫文檔。

提示:盡管唯一索引有助于定位信息,但為獲得最佳性能結果,建議改用主鍵或唯一約束。

唯一索引

唯一索引是不允許其中任何兩行具有相同索引值的索引。

當現有數據中存在重復的鍵值時,大多數數據庫不允許將新創建的唯一索引與表一起保存。數據庫還可能防止添加將在表中創建重復鍵值的新數據。例如,如果在 employee 表中職員的姓 (lname) 上創建了唯一索引,則任何兩個員工都不能同姓。

主鍵索引

數據庫表經常有一列或列組合,其值唯一標識表中的每一行。該列稱為表的主鍵。

在數據庫關系圖中為表定義主鍵將自動創建主鍵索引,主鍵索引是唯一索引的特定類型。該索引要求主鍵中的每個值都唯一。當在查詢中使用主鍵索引時,它還允許對數據的快速訪問。

聚集索引

在聚集索引中,表中行的物理順序與鍵值的邏輯(索引)順序相同。一個表只能包含一個聚集索引。

如果某索引不是聚集索引,則表中行的物理順序與鍵值的邏輯順序不匹配。與非聚集索引相比,聚集索引通常提供更快的數據訪問速度。


建立方式和注意事項

最普通的情況,是為出現在where子句的字段建一個索引。為方便講述,我們先建立一個如下的表。

CREATE TABLE mytable (

 id serial primary key,

 category_id int not null default 0,

 user_id int not null default 0,

 adddate int not null default 0

);

如果你在查詢時常用類似以下的語句:

 SELECT * FROM mytable WHERE category_id=1;

最直接的應對之道,是為category_id建立一個簡單的索引:

 CREATE INDEX mytable_categoryid

 ON mytable (category_id);

OK.如果你有不止一個選擇條件呢?例如:

 SELECT * FROM mytable WHERE category_id=1 AND user_id=2;

你的第一反應可能是,再給user_id建立一個索引。不好,這不是一個最佳的方法。你可以建立多重的索引。

CREATE INDEX mytable_categoryid_userid ON mytable (category_id,user_id);

注意到我在命名時的習慣了嗎?我使用"表名_字段1名_字段2名"的方式。你很快就會知道我為什么這樣做了。

現在你已經為適當的字段建立了索引,不過,還是有點不放心吧,你可能會問,數據庫會真正用到這些索引嗎?測試一下就OK,對于大多數的數據庫來說,這是很容易的,只要使用EXPLAIN命令:

EXPLAIN

 SELECT * FROM mytable

WHERE category_id=1 AND user_id=2;

 This is what Postgres 7.1 returns (exactly as I expected)

 NOTICE: QUERY PLAN:

 Index Scan using mytable_categoryid_userid on

 mytable (cost=0.00..2.02 rows=1 width=16)

EXPLAIN

以上是postgres的數據,可以看到該數據庫在查詢的時候使用了一個索引(一個好開始),而且它使用的是我創建的第二個索引。看到我上面命名的好處了吧,你馬上知道它使用適當的索引了。

接著,來個稍微復雜一點的,如果有個ORDER BY字句呢?不管你信不信,大多數的數據庫在使用order by的時候,都將會從索引中受益。

 SELECT * FROM mytable

WHERE category_id=1 AND user_id=2

 ORDER BY adddate DESC;

很簡單,就象為where字句中的字段建立一個索引一樣,也為ORDER BY的字句中的字段建立一個索引:

 CREATE INDEX mytable_categoryid_userid_adddate

 ON mytable (category_id,user_id,adddate);

 注意: "mytable_categoryid_userid_adddate" 將會被截短為

"mytable_categoryid_userid_addda"

 CREATE

 EXPLAIN SELECT * FROM mytable

WHERE category_id=1 AND user_id=2

 ORDER BY adddate DESC;

 NOTICE: QUERY PLAN:

 Sort (cost=2.03..2.03 rows=1 width=16)

-> Index Scan using mytable_categoryid_userid_addda

 on mytable (cost=0.00..2.02 rows=1 width=16)

 EXPLAIN

看看EXPLAIN的輸出,數據庫多做了一個我們沒有要求的排序,這下知道性能如何受損了吧,看來我們對于數據庫的自身運作是有點過于樂觀了,那么,給數據庫多一點提示吧。

為了跳過排序這一步,我們并不需要其它另外的索引,只要將查詢語句稍微改一下。這里用的是postgres,我們將給該數據庫一個額外的提示--在 ORDER BY語句中,加入where語句中的字段。這只是一個技術上的處理,并不是必須的,因為實際上在另外兩個字段上,并不會有任何的排序操作,不過如果加入,postgres將會知道哪些是它應該做的。

 EXPLAIN SELECT * FROM mytable

WHERE category_id=1 AND user_id=2

 ORDER BY category_id DESC,user_id DESC,adddate DESC;

 NOTICE: QUERY PLAN:

 Index Scan Backward using

mytable_categoryid_userid_addda on mytable

 (cost=0.00..2.02 rows=1 width=16)

 EXPLAIN

現在使用我們料想的索引了,而且它還挺聰明,知道可以從索引后面開始讀,從而避免了任何的排序。

以上說得細了一點,不過如果你的數據庫非常巨大,并且每日的頁面請求達上百萬算,我想你會獲益良多的。不過,如果你要做更為復雜的查詢呢,例如將多張表結合起來查詢,特別是where限制字句中的字段是來自不止一個表格時,應該怎樣處理呢?我通常都盡量避免這種做法,因為這樣數據庫要將各個表中的東西都結合起來,然后再排除那些不合適的行,搞不好開銷會很大。

如果不能避免,你應該查看每張要結合起來的表,并且使用以上的策略來建立索引,然后再用EXPLAIN命令驗證一下是否使用了你料想中的索引。如果是的話,就OK。不是的話,你可能要建立臨時的表來將他們結合在一起,并且使用適當的索引。

要注意的是,建立太多的索引將會影響更新和插入的速度,因為它需要同樣更新每個索引文件。對于一個經常需要更新和插入的表格,就沒有必要為一個很少使用的where字句單獨建立索引了,對于比較小的表,排序的開銷不會很大,也沒有必要建立另外的索引。

以上介紹的只是一些十分基本的東西,其實里面的學問也不少,單憑EXPLAIN我們是不能判定該方法是否就是最優化的,每個數據庫都有自己的一些優化器,雖然可能還不太完善,但是它們都會在查詢時對比過哪種方式較快,在某些情況下,建立索引的話也未必會快,例如索引放在一個不連續的存儲空間時,這會增加讀磁盤的負擔,因此,哪個是最優,應該通過實際的使用環境來檢驗。

在剛開始的時候,如果表不大,沒有必要作索引,我的意見是在需要的時候才作索引,也可用一些命令來優化表,例如MySQL可用"OPTIMIZE TABLE"。

綜上所述,在如何為數據庫建立恰當的索引方面,你應該有一些基本的概念了。

標簽:廣西 撫順 文山 吉林 商洛 玉溪 瀘州 濟源

巨人網絡通訊聲明:本文標題《數據庫為何要建立索引的原因說明》,本文關鍵詞  數據庫,為何,要,建立,索引,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《數據庫為何要建立索引的原因說明》相關的同類信息!
  • 本頁收集關于數據庫為何要建立索引的原因說明的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一级日韩不卡播放免费| 美女爽到高潮91| 亚洲最新视频在线播放| 一本一本久久a久久精品综合麻豆| 综合婷婷亚洲小说| 337p日本欧洲亚洲大胆精品| 91浏览器入口在线观看| 久久99久久99精品免视看婷婷| 欧美性极品少妇| 亚洲精品乱码久久久久久日本蜜臀| 国产美女精品在线| 色94色欧美sute亚洲线路一久| 国产传媒久久文化传媒| 丝袜国产日韩另类美女| 日韩一区欧美小说| 欧美一区二区三区视频在线| 日韩精品乱码免费| 久久午夜羞羞影院免费观看| 色综合天天做天天爱| 首页国产丝袜综合| 91精品婷婷国产综合久久性色| 91在线一区二区三区| 欧美一区二区网站| 国内精品在线播放| 福利电影一区二区三区| av电影在线观看一区| 国内欧美视频一区二区| 91丨porny丨在线| 激情综合色播激情啊| 国产电影一区在线| 开心九九激情九九欧美日韩精美视频电影| 久久一夜天堂av一区二区三区| 欧美美女bb生活片| 国产精品高清亚洲| 久久综合色综合88| 亚洲影视在线播放| 一级日本不卡的影视| 91精品国产综合久久精品性色| 成人国产精品免费观看动漫| 日韩免费观看高清完整版在线观看| 欧美亚日韩国产aⅴ精品中极品| 91视频免费看| 在线精品亚洲一区二区不卡| 色偷偷成人一区二区三区91| av不卡一区二区三区| 国产日韩欧美综合在线| 秋霞电影网一区二区| 91福利资源站| 波多野结衣一区二区三区| 91九色最新地址| 国产精品国产三级国产aⅴ中文| 丝袜美腿高跟呻吟高潮一区| av中文一区二区三区| 欧美剧情电影在线观看完整版免费励志电影| 91在线高清观看| 亚洲人成伊人成综合网小说| 青娱乐精品视频在线| 麻豆成人综合网| 国产无遮挡一区二区三区毛片日本| 中文字幕乱码亚洲精品一区| 国产精品一区二区免费不卡 | 韩国v欧美v亚洲v日本v| 午夜国产精品一区| av色综合久久天堂av综合| 在线亚洲人成电影网站色www| 亚洲一区av在线| 91久久线看在观草草青青| 亚洲精品视频免费看| 欧美一区二区三区思思人| 99久久精品国产毛片| 精品一区二区三区免费| 爽爽淫人综合网网站| 日韩精品一区二区在线观看| 日韩一区二区中文字幕| 在线观看日韩精品| 一区二区三区在线免费播放| 国模一区二区三区白浆| 欧美国产国产综合| 欧美一区二区精品久久911| 日韩一区二区电影| 91精品福利在线一区二区三区| 欧美在线啊v一区| av在线这里只有精品| 亚洲精品成人a在线观看| 欧美肥大bbwbbw高潮| 免费xxxx性欧美18vr| 欧美国产一区二区| 久久久久青草大香线综合精品| 欧美三级午夜理伦三级中视频| 在线欧美日韩精品| 欧美日韩电影一区| 日韩欧美一级特黄在线播放| 岛国精品在线观看| 精品亚洲国产成人av制服丝袜| 欧美羞羞免费网站| 欧美性生活一区| 成人午夜免费电影| 青娱乐精品视频| 亚洲电影在线免费观看| 在线观看视频91| 成人午夜激情视频| 久久久亚洲欧洲日产国码αv| 一级精品视频在线观看宜春院| 亚洲一区二区欧美激情| 日日欢夜夜爽一区| 夜夜亚洲天天久久| 欧美高清视频在线高清观看mv色露露十八| 日韩一区二区不卡| 亚洲成人午夜电影| 国产成人av一区二区三区在线| 国产成人亚洲综合a∨猫咪| 国产麻豆精品在线| 日韩美女精品在线| av激情亚洲男人天堂| 99久久免费精品高清特色大片| 日韩三级在线观看| 亚洲天堂免费看| 中日韩av电影| 激情伊人五月天久久综合| 国产精品一区二区三区乱码| 国产一本一道久久香蕉| 欧美国产精品劲爆| 婷婷一区二区三区| 成人免费在线视频| 日韩一区欧美二区| 欧美色视频一区| 亚洲视频图片小说| 国产精品嫩草影院av蜜臀| 天堂精品中文字幕在线| 午夜视频一区二区三区| 看片的网站亚洲| 欧洲国内综合视频| 国产精品久久久久桃色tv| 久久久www免费人成精品| 欧美无乱码久久久免费午夜一区| 欧美三级午夜理伦三级中视频| 国产欧美一区二区在线观看| 国产欧美精品日韩区二区麻豆天美| 成人国产精品免费观看视频| 国产精品久久久久7777按摩| 精品综合久久久久久8888| 91免费版在线| 亚洲伦理在线精品| 亚洲成人自拍网| 懂色av中文一区二区三区 | 日本一区二区三区dvd视频在线| 99久久精品情趣| 丁香亚洲综合激情啪啪综合| 日韩理论片网站| 9191国产精品| 国模无码大尺度一区二区三区| 日韩欧美国产1| 国产精品高潮呻吟| 国产亚洲精品中文字幕| 日本高清不卡视频| 日韩高清不卡一区| 欧美午夜电影网| 粉嫩av一区二区三区粉嫩| 日本色综合中文字幕| 欧美人狂配大交3d怪物一区| 久久综合色鬼综合色| 国产麻豆精品95视频| 精品少妇一区二区| 国产成人aaa| 久久99精品久久久久| 久久蜜桃香蕉精品一区二区三区| 91蜜桃传媒精品久久久一区二区| 视频在线观看国产精品| 亚洲少妇中出一区| 精品精品国产高清a毛片牛牛 | 日本vs亚洲vs韩国一区三区| 国产精品国产三级国产普通话99| 亚洲欧美激情插| 成人av网址在线| 秋霞午夜av一区二区三区| 欧美私人免费视频| 国产日韩欧美精品一区| 久久久亚洲欧洲日产国码αv| 色综合久久中文综合久久牛| 日本人妖一区二区| 亚洲黄色片在线观看| 久久久久久久国产精品影院| 日韩欧美一区二区不卡| 制服丝袜一区二区三区| 欧美综合亚洲图片综合区| 亚洲www啪成人一区二区麻豆| 国产精品天干天干在观线| 一区二区三区欧美| 国产午夜亚洲精品午夜鲁丝片| 亚洲少妇30p| 激情综合网天天干| 国产高清精品在线| 久久精品国产亚洲一区二区三区| 国产精品私房写真福利视频| 日本一区二区三区dvd视频在线| 欧美www视频| 色噜噜狠狠成人网p站| 欧美日韩成人一区| 国产欧美久久久精品影院| 一区二区三区中文字幕在线观看|