Oracle DBA(EBS 11i) 资料仓库。。。
===========================================================
===========================================================
......

摘 要:本文对Oracle数据库及ORACLE应用程序的优化,进行了全面的分析与研究,并提出了自己的一些建议。

  关 键 词:ORACLE,优化,数据库,SQL
  1.引言

  随着信息化时代的到来,人们开始广泛地使用数据库技术对大量而复杂的信息进行科学高效的管理。在数据库领域中的各种应用软件大量涌现,有Visual Foxpro,Power Builder等等,但其中ORACLE是这个领域中最优秀也是最流行的大型数据库应用软件。本文就在ORACAL中如何优化数据库及其应用程序进行了研究。

  2.优化数据库

  2.1 优化设置控制文件的个数,位置及其备份
建议CONTROL_FILE初始化参数中指定多个文件应大于2,并将控制文件镜像到不同位置,并要把这些控制文件备份到安全的磁盘中。

  2.2优化设计表空间,数据文件的大小及位置

  2.2.1设计表空间

  尽量把同一时间对磁盘的读写操作分散开,如对一个表中数据进行更新时,数据库将同时去读该表中的数据和该表上的索引信息,如果把表的数据信息和索引信息都放在同一个数据文件中,则数据库的速度将会变慢。最好是把数据信息和索引信息分别放在不同磁盘的两个数据文件中,此时数据库对磁盘的读写操作将分散在两个磁盘上,速度将得到显著提高。因此在设计数据库的表空间和数据文件时,首先给表和表的索引分别创建两个表空间(存放用户数据的数据表空间和存放表索引的索引表空间)。另外,还根据该系统的数据量的大小及系统中的数据的性质不同,再考虑创建几个数据表空间或者给数据表空间添加几个数据文件。

  2.2.2设计数据文件的大小

  把记录大小相当的表放在同一个表空间中,这时一个表空间的存储参数设置,可以保证表中的记录都放在一个范围中,避免了一条记录跨范围存放,可以明显数据库的性能。

  2.2.3设计数据文件的位置

  为了避免磁盘的I/O操作冲突,应把数据文件创建在不同位置。

2.3优化设计重演日志文件

  2.3.1 重演日志文件的大小

  由于数据库在利用重演日志文件时是循环使用它们的,而且当LGWR进程在两个日志文件切换时,将自动产生一个检测点,所以重演日志文件的大小会直接影响到检测点出现的频率。而由于在数据库检测点时,对用户而言,数据库的速度会受影响,所以检测点的出现频率大,或者检测点正好出现在数据库处理数据高峰期,将会极大影响数据库的性能。因此,重演日志文件的大小设计,应考虑检测点出现的频率以及检测点应避开数据库处理数据的高峰期。

  2.3.2 重演日志文件组的个数

  在ARCHIVELOG模式下时,适当增加重演日志文件组的个数,可以降低数据库存档日志文件的频率。

  2.3.3 重演日志文件的存档

  应把重演日志文件的存档之处设置在磁盘读写更快的物理设备上。这样可以减少日志文件的存档时间。

  2.4 回滚段的优化设计

  2.4.1 回滚段数目的设计

  要考虑数据库需要支持的并发事务的数目,因为每个回滚段有其所能支持的最大事务数,如果回滚段数目不够多,则有些新事务被迫要等待,将影响数据库的性能。

  2.4.2 回滚段大小的设计

  要考虑该回滚段能容纳数据库可能的最大事务的回滚项数。

  2.5 优化数据库使用的内存配置

  要调整数据库的高速缓冲区,共享池、重演日志缓冲区和进程全局区的大小平衡问题。

  3.优化应用程序

  3.1 采取统一的SQL程序

  因为Oracle在执行SQL文时,首先将当前要执行的SQL文与公共区域中保存的先前执行过的SQL文进行比较,SQL文相同时,就会跳过当前要执行的SQL文的解析处理,这样通过减少解析次数就加快SQL文的执行速度。

  3.2 选取合适的SQL代码

  在进行数据库操作时,同一结果可以用很多方法来实现。我们应当选取合适的SQL代码,使其更容易明了,并且运行速度更快。

  3.3 明确列名

  使用SELECT取得的列名一定要明确指定,并且应当使抽出的记录要尽量少。用SORT等的场合,因为ORACLE将必要的列的值放到WORK领域,因此减少列数也就节约了I/O回数。

  3.4 注意结合索引的顺序

  由于列的顺序不同而导致索引的作用效果不同。例如:(AGE,ADDRESS)顺序的结合索引。

WHERE AGE=28 AND ADDRESS='BEI JING' &结合索引有效
WHERE AGE=28 &结合索引有效
WHERE ADDRESS='BEI JING' &结全索引无效

  3.5 注意WHERE的使用

  3.5.1 索引列不要使用函数

  由于索引列一旦使用了函数,索引就会变无效,因此在能用索引的情况下,尽量改变程序来利用索引。如:

WHERE SUBSTR(TELNO,2,2)='88'改为WHERE TELNO LIKE '88%'较好。

  3.5.2 索引列不要使用NOT

  由于索引列一旦使用不等于,索引就会变得无效,最后导致速度变慢。

  3.5.3 不要用NULL

  如果用了NULL,索引就会无效,变成全表检索,影响处理速度。

  3.5.4 不要对索引列进行计算

  如果对索引列进行计算,索引就会无效,也后导致速度变慢。

  4.结束语

  本文所提出的优化方法,能够起到提高ORACLE数据库性能以及提高ORACLE应用程序执行效率的作用。这仅是个人在实际工作中的经验总结,希望能够对广大同行起到一定帮助作用。

zhulch 发表于:2006.09.26 09:20 ::分类: ( ERP(Oracle/SAP) ) ::阅读:(6080次) :: 评论 (1)
re: Oracle数据库及应用程序优化 [回复]

中国电视节目预订网(http://tv.orinno.com)
简介
中国电视节目预订网是全球首个提供电视节目订阅服务的网站,同时也提供电视节目的下载服务,我们已和多家大型媒体公司达成了合作协议或意向。网站提供全国所有省级以上电视台(包括香港凤凰卫视等港台电视台)的主要节目供用户收看。网站服务用户范围广、技术成熟可靠,发展潜力巨大,将成为媒体和投资界的重要合作伙伴。
网站运营的基本思路是:为用户提供电视节目预订和下载服务,用户只要事先订好喜欢看的节目,该节目的每一期在播出后就会自动下载至用户的电脑,之后用户随时可以观看。网站服务对象(用户群体)为:有上网条件的各类人群,典型例子如:不想错过想看的每期节目的电视迷、工作时间不稳定的人、不想熬夜看球的球迷等。
中国电视节目预订网彻底打破了电视节目的时间、频道限制,用户可以在任何时间收看任何一个电视频道已播出的节目,甚至是看到几个频道同时播出的节目。
  特点
操作简便。提前预订,自动下载。用户只需一次预订好自己想看的节目,当每期节目播出后,客户端就会自动下载,用户以后不用再做任何操作就随时都能看到最新的节目,特别适合对电脑操作不很熟悉的人士使用。
完全免费。中国电视节目预订网对所有用户完全免费,用户尽可以把想看的节目全部订阅或者下载下来,而不用担心费用问题。
图像质量高。图像质量远高于直播方式的网络电视。由于没有直播实时性的要求,在节目录制和压缩时采用了较高的码率和更复杂的压缩算法,使得图像效果达到接近DVD的水平,我们的用户对此都特别满意。
节目齐全。作为负责任和有远大目标的服务商,中国电视节目预订网为用户提供主要电视台的节目。对于这些节目中的大部分来说,中国电视节目预订网是唯一稳定可靠的网络获取来源。
同时看多个电视台。由于我们的系统同时录制几十个频道的电视节目,因此当您喜爱的几个节目同时播出时,您可以通过直播看一个,其他的预订就可以在其他时间再看。
技术成熟,稳定可靠。由于采用先下载再播放的方式,就没有直播所经常遇到的缓存不足等问题,保证用户可以持续稳定的收视,成熟的P2P下载技术使得系统可以支持数量庞大的用户,不用担心下载速度问题。
支持点播。可以点播式观看,不必等待下载完成,最大限度的节约用户的时间。

dd 评论于: 2006.10.17 16:46

发表评论
标题

在此添加评论
表情符号: smile laughing tongue angry crying sad wassat wink

称呼

邮箱地址(可选)

个人主页(可选)

 authimage


自我介绍
切换风格
新闻聚合
博客日历
文章归档...
最新发表...
最新评论...
最多阅读文章...
最多评论文章...
博客统计...
Blog信息
网站链接...