Oracle索引的优化设计

数据库 Oracle
使用Oracle索引可以有效提高数据库的查询效率,那么,应该如何设计Oracle索引呢?下文就该问题作了详尽的说明,供您参考徐诶。

通过合理使用和管理Oracle索引,可以加快数据库的查询效率,下面就为您详细介绍Oracle索引的优化设计,希望能够对您有所启迪。

1、管理组织索引

Oracle索引可以大大加快数据库的查询速度,Oracle索引把表中的逻辑值映射到安全的RowID,因此索引能进行快速定位数据的物理地址。但是有些DBA发现,对一个大型表建立的索引,并不能改善数据查询速度,反而会影响整个数据库的性能。

这主要是和SGA的数据管理方式有关。ORACLE在进行数据块高速缓存管理时,索引数据比普通数据具有更高的驻留权限,在进行空间竞争时,ORACLE会先移出普通数据。对一个建有索引的大型表的查询时,索引数据可能会用完所有的数 据块缓存空间,ORACLE不得不频繁地进行磁盘读写来获取数据,因此在对一个大型表进行分区之后,可以根据相应的分区建立分区索引。

如果对这样大型表的数据查询比较频繁,或者干脆不建索引。另外,DBA创建索引时,应尽量保证该索引最可能地被用于where子句中,如果对查询只简单地制定一个索引,并不一定会加快速度,因为索引必须指定一个适合所需的访问路径。

2、聚簇的使用

Oracle提供了另一种方法来提高查询速度,就是聚簇(Cluster)。所谓聚簇,简单地说就是把几个表放在一起,按一定公共属性混合存放。聚簇根 据共同码值将多个表的数据存储在同一个Oracle块中,这时检索一组Oracle块就同时得到两个表的数据,这样就可以减少需要存储的Oracle块, 从而提高应用程序的性能。

3、优化设置的索引,就必须充分利用才能加快数据库访问速度。ORACLE要使用一个索引, 有一些最基本的条件:

1)、where子名中的这个字段,必须是复合索引的***个字段;

2)、where子名中的这个字段,不应该参与任何形式的计算。

 

 

 

【编辑推荐】

Oracle索引的类型

oracle并行查询一列的实现

ORACLE ROWNUM语句的使用

Oracle索引的类型

创建Oracle索引的方法

责任编辑:段燃 来源: 互联网
相关推荐

2017-08-25 15:28:20

Oracle性能优化虚拟索引

2010-05-05 11:48:27

Oracle设计开发阶

2009-10-20 18:32:25

Oracle 10g

2010-06-03 09:24:46

Oracle

2011-06-27 16:26:39

Oracle优化器RBOCBO

2010-10-26 17:34:03

Oracle索引

2010-11-16 09:18:39

oracle重建索引

2010-10-26 16:33:54

创建Oracle索引

2010-05-12 14:04:29

Oracle优化器

2010-04-14 12:51:10

Oracle性能

2010-10-26 17:17:37

创建ORACLE索引

2010-10-26 13:30:25

oracle RMAN

2010-04-20 10:49:45

Oracle数据库

2012-09-20 10:13:04

MongoDB

2017-07-25 12:07:14

MySQL索引SQL

2011-05-20 11:33:06

ORACLE索引约束

2020-12-09 10:10:24

MySQL数据库算法

2009-11-17 13:49:46

Oracle prim

2011-06-14 10:43:44

索引

2020-10-19 19:45:58

MySQL数据库优化
点赞
收藏

51CTO技术栈公众号