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

大龍的博客

常用鏈接

統計

最新評論

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

1.B樹索引的相關概念

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

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

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

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

      B樹索引是一個典型的樹結構,其包含的組件主要是:

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

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

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

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

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

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

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

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

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



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

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

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

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


轉自:http://space.itpub.net/?uid-9842-action-viewspace-itemid-321866

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


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            午夜欧美不卡精品aaaaa| 久久免费99精品久久久久久| 欧美另类专区| 99精品欧美一区二区蜜桃免费| 男人插女人欧美| 免费中文日韩| 一区二区国产日产| 99这里有精品| 国产欧美日韩不卡免费| 久久人人爽人人爽| 久久久噜久噜久久综合| 亚洲国产精品va在线观看黑人| 亚洲国产三级网| 欧美久久精品午夜青青大伊人| 亚洲小少妇裸体bbw| 亚洲欧美日韩国产另类专区| 国精产品99永久一区一区| 免费看黄裸体一级大秀欧美| 欧美大片一区二区| 午夜国产精品影院在线观看| 久久国产日本精品| 亚洲人妖在线| 亚洲伊人一本大道中文字幕| 激情小说另类小说亚洲欧美| 亚洲精品资源美女情侣酒店| 国产精品视频免费观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美极品影院| 久久久久久久久久久久久女国产乱 | 欧美精品www| 欧美在线www| 欧美丰满少妇xxxbbb| 亚洲综合丁香| 蜜乳av另类精品一区二区| 亚洲女人小视频在线观看| 六十路精品视频| 欧美亚洲专区| 欧美激情第六页| 久久亚洲私人国产精品va媚药| 欧美岛国在线观看| 久久婷婷激情| 国产精品看片资源| 亚洲片区在线| 尤物在线精品| 香蕉久久a毛片| 夜夜爽www精品| 久久亚洲一区| 久久av资源网| 国产精品久久福利| 亚洲精品乱码| 亚洲人成亚洲人成在线观看图片 | 久久久一区二区| 欧美日韩亚洲一区三区| 亚洲第一主播视频| 狠狠色香婷婷久久亚洲精品| 中国成人在线视频| 一本色道久久综合| 欧美成人资源| 欧美成人影音| 国语自产精品视频在线看| 亚洲深夜福利在线| 亚洲视频在线观看视频| 欧美国产在线观看| 亚洲第一久久影院| 亚洲国产经典视频| 久久综合国产精品台湾中文娱乐网| 欧美伊久线香蕉线新在线| 国产精品国产三级国产aⅴ浪潮| 亚洲国产另类久久久精品极度| 尹人成人综合网| 久久裸体视频| 免费视频久久| 亚洲精品久久久一区二区三区| 另类av导航| 91久久亚洲| 中国成人黄色视屏| 国产精品乱码一区二区三区| 亚洲天堂视频在线观看| 亚洲亚洲精品三区日韩精品在线视频| 欧美日韩一区二区三区在线看| 亚洲精品欧美在线| 亚洲综合日韩在线| 国产亚洲激情视频在线| 久久精品卡一| 欧美二区在线观看| 一区二区高清视频在线观看| 国产精品九九久久久久久久| 亚洲一区二区三区在线播放| 久久精品72免费观看| 精品999日本| 欧美aaaaaaaa牛牛影院| 亚洲免费观看高清在线观看 | 在线观看不卡av| 欧美激情一区二区三区成人| 亚洲美女区一区| 久久大逼视频| 亚洲日本欧美| 国产精品video| 久久国产免费| 99国产精品久久久| 久久精品国产99| 日韩小视频在线观看专区| 国产精品对白刺激久久久| 欧美一区二区三区四区在线观看地址| 免费在线欧美视频| 亚洲欧美日本国产有色| 精品51国产黑色丝袜高跟鞋| 欧美日韩网站| 久久久亚洲午夜电影| aa亚洲婷婷| 免费观看亚洲视频大全| 亚洲午夜一区二区| 亚洲黑丝在线| 国产毛片久久| 欧美日韩亚洲精品内裤| 久久久人人人| 亚洲一区二区视频| 亚洲国产天堂久久综合网| 欧美一区二区三区另类 | 国产亚洲一本大道中文在线| 麻豆精品在线视频| 午夜精品久久久久久久久| 亚洲国产va精品久久久不卡综合| 欧美亚洲色图校园春色| 日韩午夜在线电影| 亚洲国产精品久久久久秋霞蜜臀 | 欧美精品激情blacked18| 欧美在线网站| 亚洲欧美日韩爽爽影院| 99综合在线| 亚洲高清一区二| 欧美成人亚洲| 免费影视亚洲| 久久一区国产| 欧美亚洲综合另类| 亚洲私人影吧| 一区二区三区日韩欧美精品| 亚洲人成77777在线观看网| 黄色成人精品网站| 国产精品一区在线观看你懂的 | 亚洲欧美日本在线| 在线亚洲+欧美+日本专区| 亚洲精品午夜精品| 亚洲国产精品久久久久婷婷884| 免费观看成人| 六十路精品视频| 老司机午夜免费精品视频| 久久精品综合网| 久久久国产精品一区| 久久久久久久激情视频| 欧美在线一级va免费观看| 欧美一区二区视频免费观看| 欧美一区二区三区四区在线观看| 先锋影院在线亚洲| 午夜精品一区二区三区在线| 欧美亚洲日本网站| 久久久亚洲人| 欧美高清在线观看| 91久久一区二区| 一区二区av在线| 亚洲影视在线| 久久精品99久久香蕉国产色戒| 久久久噜噜噜久噜久久| 欧美成人一区二区三区在线观看| 欧美激情精品久久久久| 欧美日韩中文字幕在线视频| 国产精品久久久久高潮| 国产三区二区一区久久| 一区在线免费观看| 亚洲人www| 午夜精品久久久久久久白皮肤| 久久精品综合网| 亚洲国产日韩欧美在线图片| 亚洲人成在线观看| 午夜欧美大片免费观看| 久久久伊人欧美| 欧美日韩中文字幕在线视频| 国产欧美精品久久| 亚洲国产婷婷香蕉久久久久久99 | 小黄鸭精品aⅴ导航网站入口| 欧美中文在线观看| 欧美大尺度在线| 亚洲午夜精品久久久久久app| 久久精品夜色噜噜亚洲a∨| 欧美女同视频| 国产一级久久| 一区二区免费看| 久久香蕉国产线看观看网| 亚洲美女福利视频网站| 欧美一级大片在线免费观看| 欧美大片91| 韩日精品视频| 午夜精品视频网站| 91久久精品日日躁夜夜躁国产| 亚洲性色视频| 欧美日韩国产综合视频在线观看| 激情综合中文娱乐网| 亚洲欧美激情诱惑| 最新国产の精品合集bt伙计| 欧美综合国产|