国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

Oracle10個分區和Mysql分區區別詳解

2024-07-24 12:52:31
字體:
來源:轉載
供稿:網友

Oracle10g分區常用的是:range(范圍分區)、list(列表分區)、hash(哈希分區)、range-hash(范圍—哈希分區)、range-list(列表—復合分區)。

Range分區:Range分區是應用范圍比較廣的表分區方式,它是以列的值的范圍來做為分區的劃分條件,將記錄存放到列值所在的range分區中。

        如按照時間劃分,2010年1月的數據放到a分區,2月的數據放到b分區,在創建的時候,需要指定基于的列,以及分區的范圍值。

       在按時間分區時,如果某些記錄暫無法預測范圍,可以創建maxvalue分區,所有不在指定范圍內的記錄都會被存儲到maxvalue所在分區中。如:

createtable pdba (id number, time date) partition by range (time)(partitionp1 values less than (to_date('2010-10-1', 'yyyy-mm-dd')),partitionp2 values less than (to_date('2010-11-1', 'yyyy-mm-dd')),partitionp3 values less than (to_date('2010-12-1', 'yyyy-mm-dd')),partitionp4 values less than (maxvalue))

Hash分區:

  對于那些無法有效劃分范圍的表,可以使用hash分區,這樣對于提高性能還是會有一定的幫助。hash分區會將表中的數據平均分配到你指定的幾個分區中,列所在分區是依據分區列的hash值自動分配,因此你并不能控制也不知道哪條記錄會被放到哪個分區中,hash分區也可以支持多個依賴列。如:

createtable test(transaction_idnumber primary key,item_idnumber(8) not null)partitionby hash(transaction_id)(partitionpart_01 tablespace tablespace01,partitionpart_02 tablespace tablespace02,partitionpart_03 tablespace tablespace03);

在這里,我們指定了每個分區的表空間。

List分區:

  List分區也需要指定列的值,其分區值必須明確指定,該分區列只能有一個,不能像range或者hash分區那樣同時指定多個列做為分區依賴列,但它的單個分區對應值可以是多個。

  在分區時必須確定分區列可能存在的值,一旦插入的列值不在分區范圍內,則插入/更新就會失敗,因此通常建議使用list分區時,要創建一個default分區存儲那些不在指定范圍內的記錄,類似range分區中的maxvalue分區。

     在根據某字段,如城市代碼分區時,可以指定default,把非分區規則的數據,全部放到這個default分區。如:

createtable custaddr(idvarchar2(15 byte) not null,areacodevarchar2(4 byte))partitionby list (areacode)(partition t_list025 values ('025'),partitiont_list372 values ('372') ,partitiont_list510 values ('510'),partitionp_other values (default))

組合分區:

      如果某表按照某列分區之后,仍然較大,或者是一些其它的需求,還可以通過分區內再建子分區的方式將分區再分區,即組合分區的方式。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邻水| 叙永县| 农安县| 彭山县| 宁强县| 霞浦县| 澄城县| 新建县| 阳朔县| 临安市| 临湘市| 陵川县| 丰原市| 盘锦市| 肥西县| 双牌县| 利津县| 清流县| 缙云县| 北海市| 安溪县| 临夏县| 岑溪市| 五寨县| 惠来县| 兴业县| 多伦县| 嘉峪关市| 平罗县| 华安县| 扎赉特旗| 天门市| 九寨沟县| 娱乐| 新闻| 宕昌县| 庄河市| 兴文县| 施秉县| 万荣县| 从化市|