• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            BerkeleyDB存儲算法差別

            HashBtree的區(qū)別
            當(dāng)記錄號不是用于數(shù)據(jù)存取的主鍵時,應(yīng)該使用 HashBtree算法 。 (如果記錄號是用于數(shù)據(jù)存取的一個二級關(guān)鍵字,那么還是可以選擇Btree算法,因?yàn)樗С忠粋€主鍵和一個記錄號同時存取。)

            Btree
            中的主鍵是有序存儲 ,記錄間的關(guān)聯(lián)是依靠次序。并且其結(jié)構(gòu)能隨數(shù)據(jù)的插入和刪除進(jìn)行動態(tài)調(diào)整。為了代碼的簡單,DB沒有實(shí)現(xiàn)對關(guān)鍵字的前綴碼壓縮。Btree支持對數(shù)據(jù)查詢、插入、刪除的常數(shù)級速度。關(guān)鍵字可以為任意的數(shù)據(jù)結(jié)構(gòu)。因此,當(dāng)在主鍵有序時,Btree算法應(yīng)該被使用 。例如,如果主鍵是時間戳,那么8點(diǎn)時間戳后面跟隨的就是9點(diǎn)時間戳, 這種情況下,Btree算法一般是正確的選擇。再來個例子:如果主鍵是名字,應(yīng)用需要取出所有同姓的記錄,那么Btree 存取方法同樣是個好選擇。

            Hash
            Btree 兩種方式在小的數(shù)據(jù)集合上幾乎沒有性能的差別 。不過,由于Hash使用的是擴(kuò)展線性HASH算法(extended linear hashing),可以根據(jù)HASH表的增長進(jìn)行適當(dāng)?shù)恼{(diào)整。所以當(dāng)一個數(shù)據(jù)集合足夠大且關(guān)鍵字為隨機(jī)分布時,采用Hash算法比較好 。

            Queue
            Recno區(qū)別
            當(dāng)用記錄號作為數(shù)據(jù)存取的主鍵時,應(yīng)該使用 QueueRecno存取方法 。記錄號由算法本身生成。實(shí)際上,這和關(guān)系型數(shù)據(jù)庫中邏輯主鍵通常定義為int AUTO型是同一個概念。兩者基本上都是建立在Btree算法之上,提供存儲有序數(shù)據(jù)的接口。Queue的優(yōu)勢在于:由于其記錄為定長,在插入操作時把記錄插入到隊(duì)列的尾部,所以速度最快,而且它執(zhí)行上鎖和并發(fā)處理的水平也相當(dāng)高。 Recno 的長處在于它支持一些Queue不能實(shí)現(xiàn)的特征,比如可變長記錄和支持flat-text文件。

            記錄號可以是可變的或者不變的: 可變指的是當(dāng)記錄被刪除或者插入記錄號發(fā)生變化;不變指的是記錄號無論數(shù)據(jù)庫如何操作,記錄號都不會發(fā)生改變。 基于記錄號存取在Btree方式下也是可行的。但是,記錄號是可變,當(dāng)記錄刪除或插入時,數(shù)據(jù)庫內(nèi)的其他記錄的記錄號都將發(fā)生改變。 Queue存取方法總是用固定的方式運(yùn)行,不管數(shù)據(jù)庫如何操作,記錄號始終改變。 Recno 可以被設(shè)置為不變和可變兩種形式。

            另外,Recno為數(shù)據(jù)庫提供支持flat-text文件的永久存儲和數(shù)據(jù)在讀或修改時提供一個快速的臨時存儲空間。

            一個表格:

            存儲方式

            描述

            選擇場景

            BTree

            關(guān)鍵字有序存儲,并且其結(jié)構(gòu)能隨數(shù)據(jù)的插入和刪除進(jìn)行動態(tài)調(diào)整。

            為了代碼的簡單, Berkeley DB 沒有實(shí)現(xiàn)對關(guān)鍵字的前綴碼壓縮。

            B+ 樹支持對數(shù)據(jù)查詢、插入、刪除的常數(shù)級速度。關(guān)鍵字可以為任意的數(shù)據(jù)結(jié)構(gòu)

            1   當(dāng) Key 為復(fù)雜類型時。

            2 、   當(dāng) Key 有序時。

            Hash

            DB 中實(shí)際使用的是擴(kuò)展線性 HASH 算法( extended linear hashing ),

            可以根據(jù) HASH 表的增長進(jìn)行適當(dāng)?shù)恼{(diào)整。關(guān)鍵字可以為任意的數(shù)據(jù)結(jié)構(gòu)。

            1 、   當(dāng) Key 為復(fù)雜類型。

            2   當(dāng)數(shù)據(jù)較大且 key 隨機(jī)分布時。

            Recno

            要求每一個記錄都有一個邏輯紀(jì)錄號,邏輯紀(jì)錄號由算法本身生成。

            相當(dāng)于關(guān)系數(shù)據(jù)庫中的自動增長字段。

            Recho 建立在 B+ 樹算法之上,提供了一個存儲有序數(shù)據(jù)的接口。

            記錄的長度可以為定長或不定長。

            1 、   當(dāng) key 為邏輯記錄號時。

            2 、   當(dāng)非高并發(fā)的情況下。

             

            Queue

            Recno 方式接近只不過記錄的長度為定長。

            數(shù)據(jù)以定長記錄方式存儲在隊(duì)列中,插入操作把記錄插入到隊(duì)列的尾部,

            相比之下插入速度是最快的。

            1 、    當(dāng) key 為邏輯記錄號時。

            2 、   定長記錄。

            3 、   高并發(fā)的情況下。

             

            posted on 2011-08-31 13:02 肥仔 閱讀(975) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫

            精品久久亚洲中文无码| 国产亚州精品女人久久久久久 | 久久精品夜色噜噜亚洲A∨| 久久精品无码专区免费东京热| 国产精品亚洲综合久久| 久久笫一福利免费导航 | 久久五月精品中文字幕| 亚洲精品高清久久| 国产成人精品久久| 丁香五月综合久久激情| 久久精品国产一区二区三区不卡| 国产A级毛片久久久精品毛片| 亚洲综合久久综合激情久久| 国产精品久久影院| 久久99国产精品久久久| 亚洲国产成人久久精品影视| 精品99久久aaa一级毛片| 色99久久久久高潮综合影院| 97视频久久久| 国产情侣久久久久aⅴ免费| 99热成人精品热久久669| 91精品国产91热久久久久福利| 久久久久免费精品国产| 国产精品无码久久久久| 久久免费视频1| 久久99精品久久只有精品| A级毛片无码久久精品免费| 久久高潮一级毛片免费| 亚洲午夜久久久影院伊人| 精品久久久久久国产91| 亚洲婷婷国产精品电影人久久| 久久天天躁狠狠躁夜夜躁2014| 精品国产一区二区三区久久久狼 | 久久99国产精一区二区三区| 精品无码久久久久久国产| 天天爽天天狠久久久综合麻豆| 欧美久久综合性欧美| 日韩久久久久久中文人妻 | 久久精品桃花综合| 成人妇女免费播放久久久| 伊色综合久久之综合久久|