详解Oracle数据货场中三种优化

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 14:25 点击:

我们在做数据库的项目时,对数据货场的优化,大约的原理只有两个:一是数据分块储藏,便于数据的转储和管教;二是其中处理,长进数据供给的速度。本文主要介绍了Oracle数据货场中的三种优化:对分区的优化、维度优化和物化视图的优化,基上面两个大约的原理,借助于数据货场的观念,罗列数据库的优化措施:

1.分区

在数据货场中,事实表,索引表,维度表分处于三个不同的表空间其中(在安排的时候,良好是安排到不同的磁盘上)。这么子做的起因即便便于并发垄断,其实数据货场和等闲的数据库之间未曾严厉的界限,重要还是安排上,当然oracle本身会为数据货场中的“事实表”生成“知识库”等垄断,保证更快的数据供给效率,其实能够借助于job和表面过程来调动存储过程告终。基于这个思路,本项目数据库中的索引将和事实表离别维护,当然这称不上分区()。恳挚的分区是指下面的内容。

分区即便partition/subpartition,对于事实表本身来说,以月为单位作partition挂载到不同表空间上。翔实的示例如下:

create table T_LOGNODE_RECORD   
(   
……   
CALLIN_HH NUMBER(2) not null,   
CALLIN_DD NUMBER(2) not null,   
CALLIN_MONTH NUMBER(2) not null,   
CALLIN_YEAR NUMBER(4) not null,   
MONTH_MOD NUMBER(1) not null   
)   
PARTITION BY LIST (MONTH_MOD)   
(   
PARTITION P0 VALUES (0) TABLESPACE TS0,   
PARTITION P1 VALUES (1) TABLESPACE TS1,   
PARTITION P2 VALUES (DEFAULT) TABLESPACE TS2   
); 
上述的代码中以MONTH_MOD字段作为分区规范,将T_LOGNODE_RECORD分到三个不同的表空间(TS0,TS1,TS2)中,这里有一个技巧,MONTH_MOD = 月份mod3,这么子能够无须要人工的维护哪个月分入哪个分区。当然容易的以月作为分区尔后,对于我们目前的数据库来说还是远远不够的,因为即便是一个月的数据依旧是很宏伟的,那么必需我们做SUBPARTITION,做法的示例为:

create table T_LOGNODE_RECORD   
(   
……   
CALLIN_DD NUMBER(2) not null,   
MONTH_MOD NUMBER(1) not null   
)   
PARTITION BY RANGE(MONTH_MOD)   
SUBPARTITION BY LIST(CALLIN_DD)   
SUBPARTITION TEMPLATE   
(   
SUBPARTITION SUBP1 values (1),   
SUBPARTITION SUBP2 values (2),   
SUBPARTITION SUBP3 values (3)   
)   
(   
PARTITION P0 VALUES less than (1),   
PARTITION P1 VALUES less than (2),   
PARTITION P2 VALUES less than (3)   
); 
分区措施有三种:RANGE(范围),LIST(列表分区),HASH(哈希分区),必需解释的HASH分区,是oracle调用内置的hash函数来告终对数据的平衡散布,保证分区内部的数据量雷同,因而只必需制订分区的数量即可。

对于复合分区来说。不是所有分区款式都能够嵌套的,oracle只扶持范围列表分区,范围哈希分区,尤其的范围分区能够扶持多个字段range by(field1,field2)。对于本项目管用到的分区措施,只有示例中给出的两种,至于分区的利益,请察看google,^_^。给出垄断的 sql示例如下:

select * from T_LOGNODE_RECORD partition(P0)   
update T_LOGNODE_RECORD partition(P0) t set…… 
insert语句未曾波及。当然上述的垄断能够像等闲的Sql语句一样,不指定分区也能够举行,但在查询的时候请尽量能确定分区和子分区 subpartition,这么子会让查询的速度长进百倍。能够剔除指定的分区drop可能truncate, EXPORT和IMPORT分区中数据,然而当举行分区的剔除垄断的时候,会使大局的索引(index)实效,必需重兴发生。

2.维度

Dimension这个算是oracle的进阶功能了,在PLSQL Developer未曾措施找到这个对象(然而能够厉行语句来生成该对象,然而无法举行后期的维护),只能在Toad中有它的身影。它是阐明数据维度字段之间的大小联系。标兵的慷慨是下面的年月日了。

create table DIM_TIME   
(   
D_YEAR VARCHAR2(4) not null

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • Table函数使用简介
      • Oracle数据库Constraint约束的常用操作及异常处理
      • Bulk Collect性能分析(zz)
      • export/import的使用
      • OCP043第十五讲 Database Security
      • ORACLE10gr2数据导入MySQL方案
      • oracle 让sys用户可以使用isqlplus
      • 在oracle数据库下使用iSQL*Plus DBA访问数据库
      • Oracle行列转换小结
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1