<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      302 隨筆 :: 26 文章 :: 82 評論 :: 0 Trackbacks
    索引組織表
    ?
    ??? 索引組織表(IOT)不僅可以存儲數據,還可以存儲為表建立的索引。索引組織表的數據是根據主鍵排序后的順序進行排列的,這樣就提高了訪問的速度。但是這是由犧牲插入和更新性能為代價的(每次寫入和更新后都要重新進行重新排序)。
    ?
    ??? 索引組織表的創建格式如下:

    ??? create table indexTable(

    ???? ? ID varchar2 ( 10 ),

    ???? ? NAME varchar2 ( 20 ),

    ???? ? constraint pk_id primary key ( ID )

    ????? )

    ???? organization index ;

    ?

    ??? 注意兩點:

    ??? ● 創建IOT時,必須要設定主鍵,否則報錯。

    ??? ● 索引組織表實際上將所有數據都放入了索引中。

    ?

    ?

    索引組織表屬性

    ?

    ??? 1、OVERFLOW子句(行溢出)

    ?

    ??? 因為所有數據都放入索引,所以當表的數據量很大時,會降低索引組織表的查詢性能。此時設置溢出段將主鍵和溢出數據分開來存儲以提高效率。溢出段的設置有兩種格式:

    ?

    ????? PCTTHRESHOLD n :制定一個數據塊的百分比,當行數據占用大小超出時,該行的其他列數據放入溢出段

    ????? INCLUDING column_name :指定列之前的列都放入索引塊,之后的列都放到溢出段

    ?

    ??????● 當行中某字段的數據量無法確定時使用PCTTHRESHOLD

    ????? ● 若所有行均超出PCTTHRESHOLD規定大小,則考慮使用INCLUDING

    ?????

    ??? create table t88(

    ???? ? ID varchar2 ( 10 ),

    ???? ? NAME varchar2 ( 20 ),

    ???? ? constraint pk_id primary key ( ID )

    ????? )

    ??? organization index

    ????? PCTTHRESHOLD 20

    ????? overflow tablespace users

    ????? INCLUDING name ;

    ?

    ??? ● 如上例所示,name及之后的列必然被放入溢出列,而其他列根據 PCTTHRESHOLD 規則。

    ?

    ??? 2、COMPRESS子句(鍵壓縮)

    ?

    ??? 與普通的索引一樣,索引組織表也可以使用COMPRESS子句進行鍵壓縮以消除重復值。

    ??? 具體的操作是,在organization index之后加上COMPRESS n子句

    ?

    ??? ● n的意義在于:指定壓縮的列數。默認為無窮大。

    ?

    ??? 例如對于數據(1,2,3)、(1,2,4)、(1,2,5)、(1,3,4)、(1,3,5)時

    ??? 若使用COMPRESS則會將重復出現的(1,2)、(1,3)進行壓縮

    ??? 若使用COMPRESS 1時,只對數據(1)進行壓縮

    ?

    ?

    索引組織表的維護

    ?

    ??? 索引組織表可以和普通堆表一樣進行INSERT、UPDATE、DELETE、SELECT操作。

    ??? 可使用ALTER TABLE ... OVERFLOW語句來更改溢出段的屬性。

    ?

    ??? altertable t88 addoverflow; --新增一個overflow

    ?

    ??? ● 要ALTER任何OVERVIEW的屬性,都必須先定義overflow,若建表時沒有可以新增

    ?

    ??? altertable t88 pctthreshold15includingname; --調整overflow的參數

    ??? altertable t88 initrans2overflowinitrans4; --修改數據塊和溢出段的initrans特性

    ?

    ??? ● 關于initrans的概念參考 http://space.itpub.net/265709/viewspace-166534

    ?

    ?

    索引組織表的應用


    ??? Heap Table 就是一般的表,獲取表中的數據是按命中率來得到的。沒有明確的先后之分,在進行全表掃描的時候,并不是先插入的數據就先獲取。數據的存放也是隨機的,當然根據可用空閑的空間來決定。

    ?

    ???? IOT 就是類似一個全是索引的表,表中的所有字段都放在索引上,所以就等于是約定了數據存放的時候是按照嚴格規定的,在數據插入以前其實就已經確定了其位置,所以不管插入的先后順序,它在那個物理上的那個位置與插入的先后順序無關。這樣在進行查詢的時候就可以少訪問很多blocks,但是插入的時候,速度就比普通的表要慢一些。
    適用于信息檢索、空間和OLAP程序。

    ?

    ??? 索引組織表的適用情況:
    ??? 1、 代碼查找表。
    ??? 2、 經常通過主碼訪問的表。
    ??? 3、 構建自己的索引結構。
    ??? 4、 加強數據的共同定位,要數據按特定順序物理存儲。
    ??? 5、 經常用between…and…對主碼或唯一碼進行查詢。
    數據物理上分類查詢。如一張訂單表,按日期裝載數據,想查單個客戶不同時期的訂貨和統計情況。

    ?

    ??? 經常更新的表當然不適合IOT,因為oracle需要不斷維護索引,而且由于字段多索引成本就大。

    ?

    ??? 如果不是經常使用主鍵訪問表,就不要使用IOT

    ?

    ?

    ?

    ?





    -The End-

    posted on 2008-10-14 17:55 decode360-3 閱讀(8278) 評論(0)  編輯  收藏 所屬分類: Oracle
    主站蜘蛛池模板: 日韩毛片免费在线观看| jlzzjlzz亚洲乱熟在线播放| 国产91免费在线观看| 亚洲一区二区三区在线视频| 免费av一区二区三区| 亚洲中文字幕久久无码| 国产精品亚洲一区二区无码| 亚洲色婷婷综合久久| 免费看一级一级人妻片| 国产zzjjzzjj视频全免费| 久久大香伊焦在人线免费| 2017亚洲男人天堂一| 黄瓜视频影院在线观看免费| 国产精品视频全国免费观看| 亚洲精品一卡2卡3卡三卡四卡| 亚洲国产成人久久综合一区77| 亚洲人成电影网站免费| 成人免费视频试看120秒| 亚洲AV无码男人的天堂| 亚洲黄色在线观看网站| 91在线视频免费观看| 人成午夜免费大片在线观看| 在线观看亚洲AV每日更新无码| 无码欧精品亚洲日韩一区| 亚洲AV无码成人精品区大在线| 在线观看成人免费视频不卡| 久久免费线看线看| 中国一级特黄的片子免费 | 免费夜色污私人影院网站电影| 亚洲欧洲日本天天堂在线观看| 成人免费无遮挡无码黄漫视频| 最近高清中文字幕免费| 三年片在线观看免费西瓜视频| 亚洲明星合成图综合区在线| 亚洲国产精彩中文乱码AV| 在线观看亚洲成人| 久久久久国产成人精品亚洲午夜| 免费看又黄又无码的网站| 91亚洲精品视频| 亚洲国产成人久久综合一区| 亚洲第一页中文字幕|