Oracle逻辑结构优化的解剖

数据库 Oracle
以下的文章主要介绍的是Oracle逻辑结构的相关优化,以下就是其具体方案的描述,希望在你今后的学习中会有所帮助。

Oracle逻辑结构优化其实就是通过增加、减少或者调整逻辑相关结构,来提高其应用的效率,以下就是通过对其基本表的设计以及索引、聚簇的讨论来分析Oracle逻辑结构的优化。以下就是文章的主要内容的介绍。

基本表扩展

数据库性能包括存储空间需求量的大小和查询响应时间的长短两个方面。为了优化数据库性能,需要对数据库中的表进行规范化。一般来说,逻辑数据库 设计满足第三范式的表结构容易维护且基本满足实际应用的要求。

所以,实际应用中一般都按照第三范式的标准进行规范化,从而保证了Oracle逻辑结构数据库的一致性和完整性, 设计人员往往会设计过多的表间关联,以尽可能地降低数据冗余。但在实际应用中这种做法有时不利于系统运行性能的优化:如过程从多表获取数据时引发大量的连接操作,在需要部分数据时要扫描整个表等,这都消耗了磁盘的I/O 和CPU 时间。

为解决这一问题,在设计表时应同时考虑对某些表进行反规范化,方法有以下几种:一是分割表。分割表可分为水平分割表和垂直分割表两种:水平分割是按照行将一个表分割为多个表,这可以提高每个表的查询速度,但查询、更新时要选择不同的表,统计时要汇总多个表,因此应用程序会更复杂。

垂直分割是对于 一个列很多的表,若某些列的访问频率远远高于其它列,就可以将主键和这些列作为一个表,将主键和其它列作为另外一个表。通过减少列的宽度,增加了每个数据页的行数,一次I/O就可以扫描更多的行(同理于内存的页式访问),从而提高了访问每一个表的速度。

但是由于造成了多表连接,所以应该在同时查询或更新不同分割表中的列的情况比较 少的情况下使用。二是保留冗余列。当两个或多个表在查询中经常需要连接时,可以在其中一个表上增加若干冗余的列,以避免表之间的连接过于频繁,一般在冗余列的数据不经常变动的情况下使用。

三是增加派生列。派生列是由表中的其它多个列的计算所得,增加派生列可以减少统计运算,在数据汇总时可以大大缩短运算时间(通过周期性结转岂不是更好?)。

因此,在数据库的设计中,数据应当按两种类别进行组织:频繁访问的数据和频繁修改的数据。对于频繁访问但是不频繁修改的数据,内部设计应当物理不规范化。对于频繁修改但并不频繁访问的数据,内部设计应当物理规范化。

有时还需将规范化的表作为Oracle逻辑结构数据库设计的基础,然后再根据整个应用系统的需要, 物理地非规范化数据。规范与反规范都是建立在实际的操作基础之上的约束,脱离了实际两者都没有意义。只有把两者合理地结合在一起,才能相互补充,发挥各自的优点。

文章出自:http://www.programbbs.com/doc/3414.htm

【编辑推荐】

  1. Oracle数据库的相关的远程复制的解决方案
  2. 一个简单的Oracle写文件例子
  3. 如何对Oracle sql 进行性能优化的调整
  4. Oracle参数及参数文件7大类解析
  5. Oracle控制文件如何高效管理
责任编辑:佚名 来源: programbbs
相关推荐

2010-04-21 16:07:04

Oracle逻辑存储结

2010-04-26 10:24:12

Oracle ASM

2010-04-14 10:32:42

Oracle数据

2010-04-27 14:44:31

Oracle存储过程

2010-05-07 16:21:08

Oracle Raw类

2010-04-28 16:53:20

Oracle 函数

2010-04-20 10:58:54

2010-04-15 14:03:37

Oracle数据库

2010-04-13 15:49:02

Oracle SGA

2011-06-27 16:26:39

Oracle优化器RBOCBO

2010-04-14 14:19:51

Oracle数据库

2011-11-28 10:50:56

JavaJVM优化

2010-05-12 14:04:29

Oracle优化器

2010-04-21 16:55:06

Oracle物理存储结

2010-10-27 13:47:50

Oracle索引

2010-10-26 13:30:25

oracle RMAN

2010-04-14 12:51:10

Oracle性能

2010-04-15 13:10:09

Oracle系统结构

2018-05-23 13:47:28

数据库PostgreSQL查询优化

2010-04-23 14:18:38

Oracle ROWI
点赞
收藏

51CTO技术栈公众号