- 浏览: 1547780 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (532)
- 软件设计师 (7)
- PSP (5)
- NET MD (9)
- Hibernate (8)
- DIY (51)
- Work (43)
- GAME (24)
- 未分类 (44)
- iPod (6)
- MySQL (39)
- JSP (7)
- 日语能力考试 (36)
- 小说 (4)
- 豆包网 (23)
- 家用电脑 (7)
- DB2 (36)
- C/C++ (18)
- baby (9)
- Linux (13)
- thinkpad (23)
- OA (1)
- UML (6)
- oracle (24)
- 系统集成 (27)
- 脑梗塞 (6)
- 车 (8)
- MainFrame (8)
- Windows 7 (13)
- 手机 (8)
- git (12)
- AHK (2)
- COBOL (2)
- Java (9)
最新评论
-
安静听歌:
... ...
UUID做主键,好还是不好?这是个问题。 -
lehehe:
http://www.haoservice.com/docs/ ...
天气预报 -
lehehe:
[url http://www.haoservice.com/ ...
天气预报 -
liubang201010:
监控TUXEDO 的软件推荐用这个,专业,权威.并能提供报警和 ...
(转载)Tuxedo中间件简介 -
tinkame:
Next[j] =-1 当j=0时;=Max{k|0<k ...
KMP字符串模式匹配详解
http://flysen.cn/a/data/orle/2009/1023/944.html
Oracle数据库设计开发阶段性能优化策略
摘 要 通过对Oracle 数据库系统物理结构和逻辑结构的分析,阐述了在Oralce数据库设计开发阶段性能优化的一些策略和方法。
关键词 Oracle 数据库 性能优化 策略
引言
Oracle是目前使用最为广泛的大型数据库管理系统,提高Oracle数据库系统的运行效率,是整个计算机信息系统高效运转的前提和保证。影响Oracle数据库应用系统性能的因素很多,既有软件方面的因素,也包括数据运行的硬件环境、网络环境、数据库管理和维护方面的因素等。数据库系统设计开发阶段是Oracle应用优化的最佳阶段,也是主动优化阶段,能达到以最小成本获得最大性能增益的目的。通过对其逻辑存储结构和物理存储结构设计进行优化,使之在满足需求条件下,时空开销性能最佳,可以解决数据库系统运行过程中性能的渐进性下降或性能突降等问题,以保证系统运行的优良性能。
Oracle数据库的逻辑结构和物理结构
Oracle 数据库的逻辑结构是由一些数据库对象组成,如数据库表空间、表、索引、段、视图、存储过程、触发器等。数据库的逻辑存储结构(表空间等)决定了数据库的物理空间是如何被使用的,数据库对象如表、索引等分布在各个表空间中。
Oracle 数据库的物理结构从操作系统一级查看,是由一个个的文件组成,从物理上可划分为:数据文件、日志文件、控制文件和参数文件。数据文件中存放了所有的数据信息;日志文件存放数据库运行期间产生的日志信息,它被重复覆盖使用,若不采用归档方式的话,已被覆盖的日志信息将无法恢复;控制文件记录了整个数据库的关键结构信息,它若被破坏,整个数据库将无法工作和恢复;参数文件中设置了很多Oracle 数据库的配置参数,当数据库启动时,会读取这些信息。
逻辑结构的优化
逻辑结构优化用通俗的话来说就是通过增加、减少或调整逻辑结构来提高应用的效率,下面通过对基本表的设计及索引、聚簇的讨论来分析ORACLE逻辑结构的优化。
1、基本表扩展
数据库性能包括存储空间需求量的大小和查询响应时间的长短两个方面。为了优化数据库性能,需要对数据库中的表进行规范化。一般来说,逻辑数据库设计满足第三范式的表结构容易维护且基本满足实际应用的要求。所以,实际应用中一般都按照第三范式的标准进行规范化,从而保证了数据库的一致性和完整性,设计人员往往会设计过多的表间关联,以尽可能地降低数据冗余。但在实际应用中这种做法有时不利于系统运行性能的优化:如过程从多表获取数据时引发大量的连接操作,在需要部分数据时要扫描整个表等,这都消耗了磁盘的I/O 和CPU 时间。
为解决这一问题,在设计表时应同时考虑对某些表进行反规范化,方法有以下几种:一是分割表。分割表可分为水平分割表和垂直分割表两种:水平分割是按照行将一个表分割为多个表,这可以提高每个表的查询速度,但查询、更新时要选择不同的表,统计时要汇总多个表,因此应用程序会更复杂。垂直分割是对于一个列很多的表,若某些列的访问频率远远高于其它列,就可以将主键和这些列作为一个表,将主键和其它列作为另外一个表。通过减少列的宽度,增加了每个数据页的行数,一次I/O就可以扫描更多的行,从而提高了访问每一个表的速度。但是由于造成了多表连接,所以应该在同时查询或更新不同分割表中的列的情况比较少的情况下使用。二是保留冗余列。当两个或多个表在查询中经常需要连接时,可以在其中一个表上增加若干冗余的列,以避免表之间的连接过于频繁,一般在冗余列的数据不经常变动的情况下使用。三是增加派生列。派生列是由表中的其它多个列的计算所得,增加派生列可以减少统计运算,在数据汇总时可以大大缩短运算时间。
因此,在数据库的设计中,数据应当按两种类别进行组织:频繁访问的数据和频繁修改的数据。对于频繁访问但是不频繁修改的数据,内部设计应当物理不规范化。对于频繁修改但并不频繁访问的数据,内部设计应当物理规范化。有时还需将规范化的表作为逻辑数据库设计的基础,然后再根据整个应用系统的需要,物理地非规范化数据。规范与反规范都是建立在实际的操作基础之上的约束,脱离了实际两者都没有意义。只有把两者合理地结合在一起,才能相互补充,发挥各自的优点。
2、索引和聚簇
创建索引是提高检索效率最有效的方法之一,索引把表中的逻辑值映射到安全的RowID,能快速定位数据的物理地址,可以大大加快数据库的查询速度,一个建有合理索引的数据库应用系统可能比一个没有建立索引的数据库应用系统效率高几十倍,但并不是索引越多越好,在那些经常需要修改的数据列上建立索引,将导致索引B*树的不断重组,造成系统性能的下降和存储空间的浪费。对于一个大型表建立的索引,有时并不能改善数据查询速度,反而会影响整个数据库的性能。这主要是和SGA的数据管理方式有关,Oracle在进行数据块高速缓存管理时,索引数据比普通数据具有更高的驻留权限,在进行空间竞争时,Oracle会先移出普通数据,对建有索引的大型表进行数据查询时,索引数据可能会用完所有的数据块缓存空间,Oracle不得不频繁地进行磁盘读写来获取数据,所以,在对一个大型表进行分区之后,可以根据相应的分区建立分区索引。
Oracle提供了另一种方法来提高查询速度,就是聚簇(Cluster)。所谓聚簇,简单地说就是把几个表放在一起,按一定公共属性混合存放。聚簇根据共同码值将多个表的数据存储在同一个Oracle块中,这时检索一组Oracle块就同时得到两个表的数据,这样就可以减少需要存储的Oracle块,从而提高应用程序的性能。
对于逻辑结构的优化,还应将表数据和索引数据分开表空间存储,分别使用独立的表空间。因为如果将表数据和索引数据放在一起,表数据的I/O操作和索引的I/O操作将产生影响系统性能的I/O竞争,降低系统的响应效率。将表数据和索引数据存放在不同的表空间中,并在物理层面将这两个表空间的数据文件放在不同的物理磁盘上,就可以避免这种竞争了。
物理结构的优化
数据库的数据最终是存储在物理磁盘上的,对数据进行访问就是对这些物理磁盘进行读写,因此对于这些物理存储的优化是系统优化的一个重要部分。对于物理存储结构优化,主要是合理地分配逻辑结构的物理存储地址,这样虽不能减少对物理存储的读写次数,但却可以使这些读写尽量并行,减少磁盘读写竞争,从而提高效率,也可以通过对物理存储进行精密的计算减少不必要的物理存储结构扩充,从而提高系统利用率。(责任编辑:admin)
1、磁盘读写并行优化
对于数据库的物理读写,Oracle系统本身会进行尽可能的并行优化,例如在一个最简单的表检索操作中,如果表结构和检索域上的索引不在一个物理结构上,那么在检索的过程中,对索引的检索和对表的检索就是并行进行的。
2、操作并行优化
操作并行的优化是基于操作语句的统计结果,首先是统计各个表的访问频率,表之间的连接频率,根据这些数据按如下原则分配表空间和物理磁盘,减少系统进程和用户进程的磁盘I/O竞争;把需要连接的表格在表空间/物理磁盘上分开;把高频访问的表格在表空间/物理磁盘上分开;把经常需要进行检索的表格的表结构和索引在表空间/物理磁盘上分开。
3、减少存储结构扩展
如果应用系统的数据库比较脆弱,并在不断地增长或缩小,这样的系统在非动态变化周期内效率合理,但是当在动态变化周期内的时候,性能却很差,这是由于Oracle的动态扩展造成的。在动态扩张的过程中,Oracle必须根据存储的要求,在创建行、行变化获取缺省值时,扩展和分配新的存储空间,而且表格的扩展往往并不是事情的终结,还可能导致数据文件、表空间的增长,这些扩展会导致在线系统反应缓慢。对于这样的系统,最好的办法就是在建立的时候预先分配足够的大小和合适的增长幅度。在一个对象建立的时候要根据应用充分地计算他们的大小,然后再根据这些数据来定义对象Initial、Next和Minextents的值,使数据库在物理存储上和动态增长次数上达到一个比较好的平衡点,使这些对象既不经常发生增长,也不过多地占用数据库。
结论
优化Oracle 数据库对提高计算机系统的可用性和效率,具有非常重要的意义, 特别是在Oracle数据库设计开发阶段,对逻辑结构和物理结构进行有效的优化设计,创建一个规划布局合理的数据库,可以获得最小的系统开销,能从根本上大大提高应用系统的整体性能,对于以后的数据库性能调整和利用都有很大的益处。
(责任编辑:admin)
发表评论
-
(转)【性能优化】ORACLE数据库性能优化概述
2010-10-28 10:37 1329原文:http://space.itpub.net ... -
(转)【sql调优】系统信息统计
2010-10-28 10:36 1180原文:http://space.itpub.net/?uid- ... -
(转)【SQL 性能优化】参数设置(优化器)
2010-10-28 10:34 1732原文:http://space.itpub.net/226 ... -
(转)sqlplus中如何插入blob数据?
2010-09-01 09:39 1909http://www.itpub.net/viewthre ... -
(转)CSV文本数据如何导入oracle(实例)
2010-08-31 13:42 1739http://blog.csdn.net/senmon20 ... -
(转)一般导入数据到Oracle有几种方法!这可是经验之谈哦!
2010-08-31 13:40 2310http://hi.baidu.com/will0690/ ... -
(转)如何将TXT,EXCEL或CSV数据导入ORACLE到对应表中
2010-08-31 13:39 5652如何将TXT,EXCEL或CSV数据导入ORACL ... -
(转)oracle 查看数据库连接备忘
2010-08-19 15:28 1078http://yezi.iteye.com/blog/ ... -
(转)从问题入手帮你解决Oracle杀死死锁进程
2010-08-19 15:26 1627http://dev.firnow.com/cou ... -
(转)oracle临时表的用法总结
2010-07-22 09:20 1412http://blog.csdn.net/wyzxg/ar ... -
(转)Oracle 临时表的应用
2010-07-22 09:19 959http://hi.baidu.com/edeed/blo ... -
(转)VC下ADO访问远程ORACLE数据库
2010-07-13 15:39 4527http://blog.csdn.net/pku2009/ ... -
(转)Oracle版本区别
2010-03-29 14:23 1762http://blog.csdn.net/pengyouc ... -
(转)Oracle数据库11g版本介绍
2010-03-29 14:18 1357http://www.oracle.com/lang/cn ... -
Oracle平台应用数据库系统的设计与开发
2009-12-31 11:14 993http://tech.163.com/05/0607/1 ... -
oracle 购买方式
2009-12-16 16:38 5636http://blog.chinaunix.net/u ... -
Oracle标准版和企业版的区别
2009-12-16 16:36 4638http://blog.chinaunix.net/u ... -
oracle 报价
2009-12-16 16:35 3010http://www.rozsoft.com/html/fxc ... -
Oracle10g New Feature:闪回恢复区空间管理
2009-11-26 13:32 1666Oracle10g New Feature:闪回恢复区空间管理 ... -
oracle database Documentation Library
2009-11-25 14:43 252610g Release 2 (10.2) ...
相关推荐
Oracle数据库设计开发阶段的性能优化是确保系统高效运行的关键环节。Oracle作为广泛应用的关系型数据库管理系统,其性能直接影响到整个信息系统的效能。优化工作涵盖软件层面、硬件环境、网络环境以及数据库管理和...
Oracle 数据库设计开发阶段的性能优化是提升计算机系统效率的关键环节。在数据库设计阶段进行优化,可以确保在最小化系统开销的同时,最大化应用系统的整体性能,并为后续的数据库调优奠定基础。本文主要探讨Oracle...
一个数据库系统的生命周期可以分成设计、开发和成品三个阶段。在设 计阶段进行数据库性能优化的成本最低,收益最大。在成品阶段进行数据库 性能优化的成本最高,收益最小。数据库的优化可以通过对网络、硬件、操 作...
本文主要探讨了在大型数据处理系统中,针对Oracle数据库的性能优化策略。作者通过实例分析,提出了一套关键的优化技术和方法,以解决系统中常见的性能问题,如吞吐量低、响应慢、数据库进程异常等问题。优化的焦点...
4. **数据库设计与开发阶段的优化**:设计和开发阶段是优化的重要环节,占性能优化的大部分成本。这包括业务规则优化、数据库架构设计、逻辑和物理结构设计,以及合理利用PL/SQL和索引策略减少锁冲突。 5. **上线后...
首先,需要明确的是,Oracle数据库性能优化是一个全生命周期的工程,它不是简单的参数调整,而是一个涉及设计、开发、配置和监控的多层面工作。在这个过程中,DBA的角色至关重要,但并非单打独斗,团队成员的协作、...
开发阶段,应注重索引策略的制定,选择最优的访问路径,避免不必要的锁冲突,并充分利用PL/SQL以提高效率。 在产品阶段,内存和CPU的优化,磁盘I/O的管理,以及对系统资源的竞争监控是关键。同时,操作系统层面的...
在整个课程设计过程中,学生不仅会接触到Oracle数据库的基本操作,如SQL查询、存储过程、触发器,还会涉及到数据库性能优化、安全性设置、备份恢复策略等高级主题。此外,系统设计还要考虑用户体验、界面友好性以及...
总之,Windows平台上Oracle数据库的性能优化是一个多维度、细致入微的过程,涵盖了数据库设计、应用程序开发、操作系统配置等多个环节。通过综合运用各种优化策略,可以最大化Oracle9i数据库在Windows环境下的运行...
Oracle数据库高级技术培训主要聚焦于性能优化,这是数据库管理中的关键环节,对于保证系统的...通过这样的高级技术培训,参与者将能够更好地理解和实践Oracle数据库的性能优化策略,从而提升系统的整体性能和服务质量。
Oracle数据库作为广泛应用于企业系统开发的关系型数据库,其性能优化和监控对于确保系统的稳定高效运行至关重要。随着Oracle数据库市场份额的不断提升,对于性能问题的关注度也在增加。本文主要探讨了Oracle数据库...
因此,本文重点讨论了超大型Oracle数据库的基础设计和优化设计,旨在帮助用户更好地理解和应用Oracle数据库。 首先,我们来分析Oracle的逻辑结构和程序结构。Oracle的逻辑结构主要由存储单元和数据库对象组成。存储...
Oracle数据库的性能优化是数据库管理员和开发人员关注的重要课题,因为数据库性能直接影响到应用程序的运行效率和用户体验。本文主要探讨了Oracle数据库性能优化中的一个重要因素——磁盘I/O竞争问题,并从分离顺序I...
Oracle数据库的性能优化是IT领域中的关键议题,...综上所述,Oracle数据库的性能优化涉及广泛的知识点,涵盖理论基础、实践技巧、误区解析和优化策略,需要全面深入学习和不断实践,以确保数据库系统的高效稳定运行。
【Oracle数据库设计与开发规范研究】 Oracle数据库是全球广泛使用的关系型数据库管理系统,以其强大的功能和灵活性备受青睐。然而,这种灵活性可能导致数据库设计不规范、效率低下。数据库设计的质量直接影响到开发...
书中还会讨论数据库性能优化策略,包括查询优化、索引策略、内存管理以及如何通过调整数据库参数来提升系统性能。同时,安全性和备份恢复策略也是数据库设计的重要环节,作者会介绍如何设置用户权限、保护数据安全...
### ORACLE数据库性能优化知识点详解 #### 一、概述 在现代信息技术领域中,数据库作为信息系统的核心组成部分,其性能的好坏直接影响着整个系统的运行效率。ORACLE作为一款广泛使用的数据库管理系统,其性能优化...
总的来说,Oracle数据库应用开发基础涵盖了数据库设计、SQL和PL/SQL编程、性能优化、安全管理和实际开发实践等多个方面。掌握这些知识不仅可以帮助你构建稳定、高效的企业级应用,还能为你的职业生涯打开更广阔的...
本文将深入探讨Oracle数据库性能优化的关键策略,以期为数据库管理提供参考。 首先,数据库服务器内存分配的调整是优化的首要任务。Oracle数据库的性能在很大程度上取决于系统全局区(SGA)的设置,其中数据缓冲区...
在信息系统开发阶段,就需要考虑数据库优化,包括设计高效的数据库模式、规范SQL编写,以及选择适合的硬件和存储解决方案。同时,持续的监控和性能分析也是必要的,通过工具如Oracle Enterprise Manager或AWR...