青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

大龍的博客

常用鏈接

統(tǒng)計

最新評論

深入研究B樹索引(一)--- 轉(zhuǎn)

1.B樹索引的相關(guān)概念

索引與表一樣,也屬于段(segment)的一種。里面存放了用戶的數(shù)據(jù),跟表一樣需要占用磁盤空間。只

不過,在索引里的數(shù)據(jù)存放形式與表里的數(shù)據(jù)存放形式非常的不一樣。在理解索引時,可以想象一本書,其中書的內(nèi)容就相當(dāng)于表里的數(shù)據(jù),而書前面的目錄就相當(dāng)于該表的索引。同時,通常情況下,索引所占用的磁盤空間要比表要小的多,其主要作用是為了加快對數(shù)據(jù)的搜索速度,也可以用來保證數(shù)據(jù)的唯一性。

      但是,索引作為一種可選的數(shù)據(jù)結(jié)構(gòu),你可以選擇為某個表里的創(chuàng)建索引,也可以不創(chuàng)建。這是因為一旦創(chuàng)建了索引,就意味著oracle對表進(jìn)行DML(包括INSERTUPDATEDELETE)時,必須處理額外的工作量(也就是對索引結(jié)構(gòu)的維護(hù))以及存儲方面的開銷。所以創(chuàng)建索引時,需要考慮創(chuàng)建索引所帶來的查詢性能方面的提高,與引起的額外的開銷相比,是否值得。

      從物理上說,索引通常可以分為:分區(qū)和非分區(qū)索引、常規(guī)B樹索引、位圖(bitmap)索引、翻轉(zhuǎn)(reverse)索引等。其中,B樹索引屬于最常見的索引,由于我們的這篇文章主要就是對B樹索引所做的探討,因此下面只要說到索引,都是指B樹索引。

      B樹索引是一個典型的樹結(jié)構(gòu),其包含的組件主要是:

<!--[if !supportLists]-->1)     <!--[endif]-->葉子節(jié)點(Leaf node):包含條目直接指向表里的數(shù)據(jù)行。

<!--[if !supportLists]-->2)     <!--[endif]-->分支節(jié)點(Branch node):包含的條目指向索引里其他的分支節(jié)點或者是葉子節(jié)點。

<!--[if !supportLists]-->3)     <!--[endif]-->根節(jié)點(Root node):一個B樹索引只有一個根節(jié)點,它實際就是位于樹的最頂端的分支節(jié)點。

可以用下圖一來描述B樹索引的結(jié)構(gòu)。其中,B表示分支節(jié)點,而L表示葉子節(jié)點。

對于分支節(jié)點塊(包括根節(jié)點塊)來說,其所包含的索引條目都是按照順序排列的(缺省是升序排列,也可以在創(chuàng)建索引時指定為降序排列)。每個索引條目(也可以叫做每條記錄)都具有兩個字段。第一個字段表示當(dāng)前該分支節(jié)點塊下面所鏈接的索引塊中所包含的最小鍵值;第二個字段為四個字節(jié),表示所鏈接的索引塊的地址,該地址指向下面一個索引塊。在一個分支節(jié)點塊中所能容納的記錄行數(shù)由數(shù)據(jù)塊大小以及索引鍵值的長度決定。比如從上圖一可以看到,對于根節(jié)點塊來說,包含三條記錄,分別為(0 B1)、(500 B2)、(1000 B3),它們指向三個分支節(jié)點塊。其中的05001000分別表示這三個分支節(jié)點塊所鏈接的鍵值的最小值。而B1B2B3則表示所指向的三個分支節(jié)點塊的地址。

      對于葉子節(jié)點塊來說,其所包含的索引條目與分支節(jié)點一樣,都是按照順序排列的(缺省是升序排列,也可以在創(chuàng)建索引時指定為降序排列)。每個索引條目(也可以叫做每條記錄)也具有兩個字段。第一個字段表示索引的鍵值,對于單列索引來說是一個值;而對于多列索引來說則是多個值組合在一起的。第二個字段表示鍵值所對應(yīng)的記錄行的ROWID,該ROWID是記錄行在表里的物理地址。如果索引是創(chuàng)建在非分區(qū)表上或者索引是分區(qū)表上的本地索引的話,則該ROWID占用6個字節(jié);如果索引是創(chuàng)建在分區(qū)表上的全局索引的話,則該ROWID占用10個字節(jié)。

      知道這些信息以后,我們可以舉個例子來說明如何估算每個索引能夠包含多少條目,以及對于表來說,所產(chǎn)生的索引大約多大。對于每個索引塊來說,缺省的PCTFREE10%,也就是說最多只能使用其中的90%。同時9i以后,這90%中也不可能用盡,只能使用其中的87%左右。也就是說,8KB的數(shù)據(jù)塊中能夠?qū)嶋H用來存放索引數(shù)據(jù)的空間大約為64888192×90%×88%)個字節(jié)。

      假設(shè)我們有一個非分區(qū)表,表名為warecountd,其數(shù)據(jù)行數(shù)為130萬行。該表中有一個列,列名為goodid,其類型為char8),那么也就是說該goodid的長度為固定值:8。同時在該列上創(chuàng)建了一個B樹索引。

在葉子節(jié)點中,每個索引條目都會在數(shù)據(jù)塊中占一行空間。每一行用23個字節(jié)作為行頭,行頭用來存放標(biāo)記以及鎖定類型等信息。同時,在第一個表示索引的鍵值的字段中,每一個索引列都有1個字節(jié)表示數(shù)據(jù)長度,后面則是該列具體的值。那么對于本例來說,在葉子節(jié)點中的一行所包含的數(shù)據(jù)大致如下圖二所示:



從上圖可以看到,在本例的葉子節(jié)點中,一個索引條目占18個字節(jié)。同時我們知道8KB的數(shù)據(jù)塊中真正可以用來存放索引條目的空間為6488字節(jié),那么在本例中,一個數(shù)據(jù)塊中大約可以放3606488/18)個索引條目。而對于我們表中的130萬條記錄來說,則需要大約36111300000/360)個葉子節(jié)點塊。

      而對于分支節(jié)點里的一個條目(一行)來說,由于它只需保存所鏈接的其他索引塊的地址即可,而不需要保存具體的數(shù)據(jù)行在哪里,因此它所占用的空間要比葉子節(jié)點要少。分支節(jié)點的一行中所存放的所鏈接的最小鍵值所需空間與上面所描述的葉子節(jié)點相同;而存放的索引塊的地址只需要4個字節(jié),比葉子節(jié)點中所存放的ROWID少了2個字節(jié),少的這2個字節(jié)也就是ROWID中用來描述在數(shù)據(jù)塊中的行號所需的空間。因此,本例中在分支節(jié)點中的一行所包含的數(shù)據(jù)大致如下圖三所示:

從上圖可以看到,在本例的分支節(jié)點中,一個索引條目占16個字節(jié)。根據(jù)上面葉子節(jié)點相同的方式,我們可以知道一個分支索引塊可以存放大約4056488/16)個索引條目。而對于我們所需要的3611個葉子節(jié)點來說,則總共需要大約9個分支索引塊。

      這樣,我們就知道了我們的這個索引有2層,第一層為1個根節(jié)點,第二層為9個分支節(jié)點,而葉子節(jié)點數(shù)為3611個,所指向的表的行數(shù)為1300000行。但是要注意,在oracle的索引中,層級號是倒過來的,也就是說假設(shè)某個索引有N層,則根節(jié)點的層級號為N,而根節(jié)點下一層的分支節(jié)點的層級號為N-1,依此類推。對本例來說,9個分支節(jié)點所在的層級號為1,而根節(jié)點所在的層級號為2


轉(zhuǎn)自:http://space.itpub.net/?uid-9842-action-viewspace-itemid-321866

posted on 2009-08-31 15:25 大龍 閱讀(434) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            有码中文亚洲精品| 国产精品婷婷| 亚洲区一区二区三区| 美女被久久久| 久久综合色影院| 亚洲激情婷婷| 日韩亚洲欧美一区二区三区| 欧美激情国产精品| 亚洲性夜色噜噜噜7777| 99亚洲一区二区| 国产精品日韩在线一区| 久久国产日韩| 免费亚洲电影在线观看| 99视频国产精品免费观看| 亚洲精品欧美极品| 国产精品成人久久久久| 欧美一区午夜视频在线观看| 欧美在线亚洲综合一区| 亚洲第一网站| 亚洲国产综合在线看不卡| 欧美成人亚洲成人| 午夜亚洲视频| 久久九九免费视频| 国产精品99久久久久久有的能看 | 亚洲大胆女人| 亚洲日韩欧美一区二区在线| 国产精品劲爆视频| 久热这里只精品99re8久| 欧美大片免费| 欧美一级网站| 欧美大片在线观看| 校园激情久久| 欧美激情亚洲综合一区| 小黄鸭精品aⅴ导航网站入口| 久久久国产一区二区| 日韩一区二区福利| 欧美主播一区二区三区| 中文国产成人精品| 久久蜜桃资源一区二区老牛| 99热免费精品在线观看| 欧美一区二区三区在线观看| 日韩一级精品视频在线观看| 欧美一区二区视频在线| 亚洲视频在线一区观看| 久久久久国产精品午夜一区| 午夜精品久久久久久久久久久| 久久久久久久久久久成人| 亚洲制服欧美中文字幕中文字幕| 蜜臀久久99精品久久久久久9| 久久精品国产精品亚洲综合| 欧美日韩亚洲一区三区| 欧美激情无毛| 国产一二三精品| 亚洲桃色在线一区| 日韩视频在线一区| 久久婷婷久久| 久久精品中文字幕一区| 国产欧美日韩在线| 一区二区三区www| 一区二区三区视频在线看| 免费91麻豆精品国产自产在线观看| 久久精品国产一区二区电影| 国产精品久久久久77777| 亚洲美女av在线播放| 在线亚洲电影| 欧美视频在线一区| 亚洲乱码国产乱码精品精天堂| 亚洲人成网站777色婷婷| 麻豆91精品| 欧美激情视频网站| 亚洲激情小视频| 欧美成人激情在线| 欧美福利在线| 亚洲乱码国产乱码精品精| 欧美激情一区二区三区在线视频| 欧美成人网在线| 亚洲乱码国产乱码精品精天堂| 欧美aⅴ一区二区三区视频| 亚洲国产精品成人久久综合一区| 亚洲激情视频在线播放| 欧美高清在线观看| 中文在线资源观看视频网站免费不卡| 中文日韩欧美| 国产欧美日韩三级| 欧美在线播放高清精品| 欧美成人午夜激情在线| 99国产成+人+综合+亚洲欧美| 欧美精品日韩综合在线| 亚洲深夜福利| 免费亚洲视频| 在线亚洲精品| 国产乱码精品一区二区三区五月婷| 午夜亚洲影视| 亚洲国产精品va在线观看黑人| 夜夜嗨av一区二区三区四季av| 欧美日韩八区| 欧美亚洲一级片| 亚洲福利小视频| 先锋影音一区二区三区| 伊人色综合久久天天| 欧美精品日韩综合在线| 亚洲影院在线| 欧美激情第8页| 午夜精品久久久久久久99水蜜桃 | 欧美日韩精品高清| 亚洲欧美电影院| 亚洲国产视频直播| 欧美一区二区播放| 99热在线精品观看| 韩国三级电影久久久久久| 欧美日韩妖精视频| 久久久久国产一区二区| 中文日韩在线视频| 欧美激情在线有限公司| 久久疯狂做爰流白浆xx| 一本大道久久a久久精二百| 国产一区二区三区四区| 欧美日韩黄色大片| 麻豆av福利av久久av| 欧美亚洲一区二区在线观看| 日韩午夜激情av| 欧美电影在线观看| 欧美专区中文字幕| 亚洲综合丁香| 中国亚洲黄色| 一本色道久久综合亚洲精品小说 | 国产精品免费一区二区三区观看| 另类春色校园亚洲| 久久9热精品视频| 亚洲综合欧美| 亚洲一区二区三区777| 91久久在线播放| 欧美国产综合一区二区| 久久综合网络一区二区| 欧美一区亚洲一区| 亚洲欧美日产图| 亚洲一区日韩在线| 亚洲图片激情小说| 亚洲色图自拍| 99综合视频| 一区二区冒白浆视频| 亚洲精品美女91| 亚洲精品国久久99热| 亚洲第一色中文字幕| 在线观看日韩www视频免费| 国内自拍视频一区二区三区| 国内综合精品午夜久久资源| 国产日韩欧美在线| 国产一区二区三区直播精品电影| 欧美色图麻豆| 国产精品爽爽爽| 国产美女精品| 黄色国产精品一区二区三区| 国产一区二区三区在线观看免费视频| 国产日韩欧美精品| 激情六月婷婷久久| 亚洲国产你懂的| 亚洲最新色图| 亚洲欧美日韩国产中文| 久久av一区二区三区| 久久精品五月| 欧美成人国产一区二区| 最新亚洲一区| 亚洲少妇在线| 欧美一区二区三区日韩视频| 久久久91精品| 欧美日本免费一区二区三区| 欧美日韩在线电影| 国产视频久久网| 亚洲第一综合天堂另类专| 亚洲精品无人区| 亚洲主播在线观看| 久久一区免费| 亚洲国产一区视频| 亚洲一区二区三区中文字幕在线| 香蕉久久夜色| 欧美高清一区| 国产亚洲欧美日韩美女| 亚洲国产精品va在线观看黑人| 日韩亚洲欧美一区| 欧美在线不卡视频| 亚洲高清免费| 亚洲欧美在线观看| 欧美成人中文字幕| 国产精品无码专区在线观看| 91久久久在线| 午夜日韩av| 亚洲欧洲另类国产综合| 亚洲欧美乱综合| 欧美日韩国产精品专区| 狠狠综合久久| 午夜精彩国产免费不卡不顿大片| 欧美成人午夜激情视频| 午夜精品视频一区| 欧美国内亚洲| 在线观看成人一级片| 欧美一区二区三区久久精品| 亚洲国产日本| 免费亚洲电影在线| 韩国成人福利片在线播放|