• 网络学院
  • IT资讯
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
保持
  站点:
  • 首 页
  • 最新软件
  • 文章教程
  • 国内软件
  • 国外软件
  • 绿色软件
  • 源码下载
  • 字体下载
保持 Oracle 数据库优良性能
软件发布 保持 Oracle 数据库优良性能
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件 绿软下载
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回文章教程首页 >> 认证考试 >> Oracle认证 >> Oracle指导 >> 保持 Oracle 数据库优良性能

保持 Oracle 数据库优良性能

添加时间: 2008-4-21 21:17:16  作者: Oracle指导  阅读次数:5   来源: http://www.d9soft.com

       

如今, Oracle 数据库以其高可靠性、 安全 性、可兼容性,得到越来越多的 企业 的青睐。如何使 Oracle 数据库保持永久的优良性能,读者不妨针对以下若干方面加以考虑。

分区

根据实际经验所得,在一个大数据库中,数据库空间的绝大多数是被少量的表所占有。如何简化大数据库和 管理 ,如何改善应用的查询性能,一般可以使用分区这种手段。所谓分区就是动态地将表中记录分离到若干不同的表空间上,使数据在物理上被分割开来,便于维护、备份、恢复、事务及查询性能。当使用的时候可建立一个连接所有分区的视图,使其在逻辑上仍以一个整体出现。

1 、建立分区表

Create table Employee (

EmpNo varchar2(10) primary key,

Name varchar2(30),

DeptNo Number(2)

)

Partition by range(DeptNo)

(

partition PART1 values less than (11)

tablespace PART1_TS,

partition PART2 values less than (21)

tablespace PART2_TS,

partition PART3 values less than (31)

tablespace PART3_TS

partition PART4 values less than (MAXVALUE)

tablespace PART4_TS

);

表 Employee 依据 DeptNo 列进行分区。

2 、分区索引

Create index Employee_DeptNo on Employee(DeptNo)

local (

partition PART1 tablespace PART1_NDX_TS,

partition PART2 tablespace PART2_NDX_TS,

partition PART3 tablespace PART3_NDX_TS,

partition PART4 tablespace PART4_NDX_TS,

);

当分区中出现许多事务并且要保证所有分区中的数据记录的唯一性时采用全局索引,如:

Create index Employee_DeptNo on Employee(DeptNo)

global partition by range (DeptNo)

(

partition PART1 values less than (11)

tablespace PART1_NDX_TS,

partition PART2 values less than (21)

tablespace PART2_NDX_TS,

partition PART3 values less than (31)

tablespace PART3_NDX_TS

partition PART4 values less than (MAXVALUE)

tablespace PART4_NDX_TS

);


在建立全局索引时, global 子句允许指定索引的范围值,这个范围值可以不同于表分区的范围值。只有建立局部索引才会使索引索引分区与表分区间建立起一一对应关系。因此,在大多数情况下,应该使用局部索引分区。若使用了此索引,分区就能够很容易地将索引分区与表分区建立关联,局部索引比全局索引更易于 管理 。 
3 、分区管理 
根据实际需要,还可以使用 alter table 命令来增加、丢弃、交换、移动、修改、重命名、划分、截短一个已存在分区的结构。 
Rebuild Indexes 
如果表中记录频繁的被删除或插入,尽管表中的记录总量保持不变,索引空间的使用量会不断增加。虽然记录从索引中被删除,但是该记录索引项的使用空间不能被重新使用。因此,如果表变化不定,索引空间量会不断增加,不管表中记录数量是否增加——只仅仅是因为索引中无效空间量的增加。 
要回收那些曾被删除记录使用的空间,需要使用 alter index rebuild 命令。可以做一个定期运行的批处理程序,来重建最活动表的索引。这个批处理程序可以在空闲时运行,以避免程序与用户冲突。若能坚持索引的这一程序规划,便可以及时回收那些未使用空间,提高空间利用率。 
段的碎片整理 
当生成一个数据库对象时(一个表或一个索引),通过用户缺省值或指定值来为它指定表空间。一个在表空间中所生成的段,用于存储对象的相关数据。在段被关闭、收缩、截断之前,段所分配的空间将不被释放。 
一个段是由范围组成,而范围是由相邻的 Oracle 块组成。一旦存在的范围不能再存储新的数据,那这个段就会去获得新的范围,且并不要求这些范围是彼此相邻的。这样的扩展会一直继续下去,直到表空间中的数据文件不能提供更多的自由空间,或者范围数量已达到极限。 
因此,一个碎片太多的数据段,不仅会影响运行,也会引发表空间中的空间管理问题。所以,每个数据段只含有一个范围是十分有益的。借助监控系统,可以通过 检查  DBA_SEGMENTS 数据字典视图来了解哪些数据库对象含有 10 个或更多范围的段,确定其数据段碎片。 
若一个段的碎片过多,可用两种方法解决这个问题: 
1 、用正确的存储参数建立一个新表,将旧表中的数据插入到新表中,再删除旧表; 
2 、利用 Export/Import 工具。 
如: exp system/manager file=exp.dmp compress=Y grants=Y indexes=Y 
tables=(T1,T2) 
若输出成功,进入 Oracle ,删除上述表。 
注: compress=Y 决定将在输出过程中修改它们的存储参数。 
imp system/manager file=exp.dmp commit=Y buffer=64000 full=Y 
注:在输入时重新配置新的存储参数。 
自由范围的碎片整理 
表空间中的一个自由范围是表空间中相连自由(空间)块的集合。当一个段关闭时,它的范围将被释放,并被标记为自由范围。然而,这些自由范围再也不能与相邻的自由范围合并,它们之间的界线始终存在。但是当表空间的缺省值 pctincrease 设置不为 0 时, SMON 后台进会定期的将这些相邻的自由范围合并。若 pctincrease 设置为 0 ,那相邻自由范围不会被数据库自动合并。但可以使用 altertable 命令 coalesce 选项,来强迫进行相邻自由范围的合并。 
不进行自由范围合并,在日后的空间请求中,会影响到表空间中的空间分配。当需要一个足够大的范围时,数据库并不会合并相邻的自由范围,除非没有其他选择。这样,当表空间中前面较小自由范围已被相关使用时,将使用表空间中后面部分最大的一个自由范围。结果,会因为它们没有足够多的使用空间,从而导致表空间中速度上的矛盾。由于这样的进程出现,使数据库的空间分配距理想越来越远。自由空间碎片常会出现在那些经常关闭又重新生成的数据库表和索引中。 
在理想的 ORACLE 表空间中,每一个数据库对象存储在一个单独的范围中,并且所有有效自由空间集中在一个巨大而连续的范围中。这样,在一个对象需要附加存储空间时,可以在增加获取足够大自由空间的可能性同时,最小化空间中的循环调用,提高自由空间使用率。

 

上下文章:

 

上一篇文章: [1Z0-031] 通过031考试与大家分享我的考试经验总结 下一篇文章: 提高ORACLE数据库的查询统计速度

相关文章:

  • 如何手动创建oracle数据库
  • Win 7 搜索性能显著优于 Vista SP1 和 XP SP3
  • oracle 多元化控制文件
  • Gartner:杀毒软件性能不佳 企业付费过高
  • SQL存储过程在.NET数据库中的应用

相关软件:

  • 腾讯QQ IP数据库 1015 纯真版
  • 计算机等级考试训练模拟软件(三级数据库技术) V1.01
  • 腾讯QQLite IP数据库 Build 1105
  • 腾讯QQ IP数据库 0730 纯真版(繁体版)
  • 网际数据库浏览器 2008 5.1.151
  • 手机通讯录信息备份数据库 2.0

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

Oracle认证分类导航

  • Oracle动态
  • Oracle指导
  • Oracle题库

本类经典文章推荐

  • Oracle中关于逻辑备份与恢复
  • Oracle开发人员JAVA存储过程
  • 为数据库的表自动生成行号
  • Oracle中的OOP概念
  • 用java从oracle取数
  • 冷备份移植到另一台Solaris机器上
  • 如何将excel数据导入oracle中
  • Oracle10.2g安装记录
  • 数据库监控工具ForOraclev1.2
  • oracle双机群集系统

Oracle指导阅读排行

  • Oracle系统表查询
  • 实例:Oracle导出EXCEL文件
  • Oracle常用的OCI函数上
  • 案例学习Oracle错误:ORA-00060
  • 案例学习Oracle错误:ORA-00604
  • Tomcat+SQLServer连接池配置
  • 如何将excel数据导入oracle中
  • Oracle企业管理器(OEM 2.1)使用...
  • ORACLE数据库简介
  • 案例学习Oracle错误:ORA-00904

Oracle认证阅读总排行

  • Oracle系统表查询
  • 实例:Oracle导出EXCEL文件
  • Oracle常用的OCI函数上
  • 在ORACLE的存储过程中如何做简单的...
  • 案例学习Oracle错误:ORA-00060
  • 案例学习Oracle错误:ORA-00604
  • Tomcat+SQLServer连接池配置
  • 如何将excel数据导入oracle中
  • Oracle企业管理器(OEM 2.1)使用...
  • AIX下自动启动Oracle数据库与监听...

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有