`

Oracle创建索引考虑因素

阅读更多
看了这个后受益匪浅



在Oracle数据库中,创建索引虽然比较简单。但是要合理的创建索引则比较困难了。笔者认为,在创建索引时要做到三个适当,即在适当的表上、适当的列上创建适当数量的索引。虽然这可以通过一句话来概括优化的索引的基本准则,但是要做到这一点的话,需要数据库管理员做出很大的努力。具体的来说,要做到这个三个适当有如下几个要求。
  一、 根据表的大小来创建索引。
  虽然给表创建索引,可以提高查询的效率。但是数据库管理员需要注意的是,索引也需要一定的开销的。为此并不是说给所有的表都创建索引,那么就可以提高数据库的性能。这个认识是错误的。恰恰相反,如果不管三七二十一,给所有的表都创建了索引,那么其反而会给数据库的性能造成负面的影响。因为此时滥用索引的开销可能已经远远大于由此带来的性能方面的收益。所以笔者认为,数据库管理员首先需要做到,为合适的表来建立索引,而不是为所有的表建立索引。
  一般来说,不需要为比较小的表创建索引。如在一个ERP系统的数据库中,department表用来存储企业部门的信息。一般企业的部分也就十几个,最多不会超过一百个。这100条记录对于人来说,可能算是比较多了。但是对于计算机来说,这给他塞塞牙缝都还不够。所以,对类似的小表没有必要建立索引。因为即使建立了索引,其性能也不会得到很大的改善。相反索引建立的开销,如维护成本等等,要比这个要大。也就是说,付出的要比得到的多,显然违反常理。
  另外,就是对于超大的表,也不一定要建立索引。有些表虽然比较大,记录数量非常的多。但是此时为这个表建立索引并一定的合适。如系统中有一张表,其主要用来保存数据库中的一些变更信息。往往这些信息只给数据库管理员使用。此时为这张表建立索引的话,反而不合适。因为这张表很少用到,只有在出问题的时候才需要查看。其次其即使查看,需要查询的纪录也不会很多,可能就是最近一周的更新记录等等。对于对于一些超大的表,建立索引有时候往往不能够达到预计的效果。而且在打表上建立索引,其索引的开销要比普通的表大的多。那么到底是否给大表建立索引呢?笔者认为,主要是看两个方面的内容。首先是需要关注一下,在这张大表中经常需要查询的记录数量。一般来说,如果经常需要查询的数据不超过10%到15%的话,那就没有必要为其建立索引的必要。因为此时建立索引的开销可能要比性能的改善大的多。这个比例只是一个经验的数据。如果数据库管理员需要得出一个比较精确的结论,那么就需要进行测试分析。即数据库管理员需要测试一下全表扫描的时间,看看其是否比建立索引后的查询时间要长或者短。如果是长的话,则说明有建立索引的必要。但是如果没有的话,则说明还是全表扫描速度来的快。此时也就没有必要建立索引了。
  总之,在考虑是否该为表建立索引时,一般来说小表没有建立索引的必要。而对于打表的话,则需要进行实际情况实际分析。简单一点的,可以根据大致的比率来确定。如果要精确一点的,则可以进行全表扫描性能分析,以判断建立索引后是否真的如预期那样改善了数据库性能。
  二、 根据列的特征来创建索引。
  列的特点不同,索引创建的效果也不同。数据库管理员需要了解为哪些列创建索引可以起到事倍功半的效果。同时也需要了解为哪些列创建索引反而起到的是事倍功半的效果。这有利于他们了解到底给为怎么样的字段建立索引。
  根据笔者的经验,往往为如下特征的列创建索引能够起到比较明显的效果。如对于一些重复内容比较少的列,特别是对于那些定义了唯一约束的列。在这些列上建立索引,往往可以起到非常不错的效果。如对于一些null值的列与非Null值的列混合情况下,如果用户需要经常查询所有的非Null值记录的列,则最好为其设置索引。如果经常需要多表连接查询,在用与连接的列上设置索引可以达到事半功倍的效果。
  可见,索引设置的是否恰当,不仅跟数据库设计架构有关,而且还跟企业的经济业务相关。为此,对于一些套装软件,虽然一开始数据库管理员已经做了索引的优化工作。但是随着后来经济数据的增加,这个索引的效果会越来越打折扣。这主要是因为记录的表化影响到了索引优化的效果。所以笔者建议各位数据库管理员,即使采用的是大牌软件公司的套装软件,也需要隔一段时间,如一年,对数据库的索引进行优化。该去掉的去掉,该调整的调整,以提高数据库的性能。
  如在数据库中有一张表是用来保存用户信息的。其中有个字段身份证号码,这是一个唯一的字段。在数据库设计时,给这个字段创建了索引。但是当这个数据库投入使用之后,用户不怎么输入用户的身份证号码。而且平时也基本不按这个号码来进行查询。当记录月来月多时,这个身份证号码上的索引字段不但不能够改善数据库的查询性能,反而成了鸡肋。对于这些有很多NULL值的列,而且不会经常查询所有的非NULL值记录的列,数据库管理员要下决心,即使清除这些列上的索引。
  所以说索引的优化与调整是一个动态的过程,并不是说数据库设计好之后就不需要经过调整。数据库管理员往往需要根据记录的变化情况,来进行适当的变更。以提高索引的效果。
  三、 在一个表上创建多少索引合适?
  虽然说,在表上创建索引的数量没有限制,但是决不是越多越好。也就是说,在创建索引这项事情上,1+1〉2往往不成立。有时候,创建索引越多,其可能会得到适得其反的效果。那么在一个表上,到底给创建多少索引合适呢?这个没有一个明确的标准。而是需要数据库管理员根据实际的用途以及数据库中记录的情况,来进行判断。
  通常来说,表的索引越多,其查询的速度也就越快。但是,表的更新速度则会降低。这主要是因为表的更新(如往表中插入一条记录)速度,反而随着索引的增加而增加。这主要是因为,在更新记录的同时需要更新相关的索引信息。为此,到底在表中创建多少索引合适,就需要在这个更新速度与查询速度之间取得一个均衡点。如对于一些数据仓库或者决策型数据库系统,其主要用来进行查询。相关的记录往往是在数据库初始化的时候倒入。此时,设置的索引多一点,可以提高数据库的查询性能。同时因为记录不怎么更新,所以索引比较多的情况下,也不会影响到更新的速度。即使在起初的时候需要导入大量的数据,此时也可以先将索引禁用掉。等到数据导入完毕后,再启用索引。可以通过这种方式来减少索引对数据更新的影响。相反,如果那些表中经常需要更新记录,如一些事务型的应用系统,数据更新操作是家常便饭的事情。此时如果在一张表中建立过多的索引,则会影响到更新的速度。由于更新操作比较频繁,所以对其的负面影响,要比查询效率提升要大的多。此时就需要限制索引的数量,只在一些必要的字段上建立索引。
  笔者在平时数据库优化时,往往会根据这些表的用途来为列设置索引。可以查询相关的动态视图,看看对于这张表的操作,是更新操作(包括更新、删除、插入等等)占的比例大,还是查询操作占的比例大。当过多的索引已经影响到更新操作的速度时,则数据库管理员就需要先禁用某些索引,以提高数据库的性能。
  总之,在适当的表、适当的列上建立适当的索引。这一句话包含的意思有很多,以上内容只是一部分内容。俗话说,师傅领进门,修行靠自身。笔者在这里指能够点到为止。一些具体的索引优化内容还是需要各位读者在日常工作中去体会与总结。


http://www.webjx.com/exam/oracle-13846.html




注意:默认是B-tree的

drop index RANDOM_EMPNO_BMX;

Index dropped.

SQL> create index random_empno_idx on test_random(empno);

Index created.


也可以是位图索引

SQL> create bitmap index normal_empno_bmx on test_normal(empno);

Index created.



下面是创建索引的方法:


适当的使用索引可以提高数据检索速度,可以给经常需要进行查询的字段创建索引

oracle的索引分为5种:唯一索引,组合索引,反向键索引,位图索引,基于函数的索引

创建索引的标准语法:

CREATE INDEX 索引名 ON 表名 (列名)

     TABLESPACE 表空间名;

创建唯一索引:

CREATE unique INDEX 索引名 ON 表名 (列名)

     TABLESPACE 表空间名;

创建组合索引:

CREATE INDEX 索引名 ON 表名 (列名1,列名2)

     TABLESPACE 表空间名;

创建反向键索引:

CREATE INDEX 索引名 ON 表名 (列名) reverse

     TABLESPACE 表空间名;





1.索引分类

a) 唯一索引,    作用是数据约束,保证数据唯一,还有就是数据索引,提高查询效率

b)一般索引,只有数据索引的作用,


2.唯一索引的建立

create unique index 索引名 on    表名(字段名)

ok,假设有一个Emploeyy表,里面有一个empName字段,我们来为empName添加唯一索引

create unique index    idx_empname on employee(empname);


3.一般索引

create index 索引名 on 表名(字段名)

ok,现在我们为employee的address字段,添加一般索引

create index idx_address on employee(address);


我们还可以为两多个字段建立索引

create unique index idx_test on employee(field1,field2);

这样,为field1,field2添加了唯一索引,field1和field2的组合是唯一的了


还可以指定索引排序

create index idx_test    employee(field1 ,field2 desc);;


4.函数索引

    如果在我们的查询条件使用了函数,那么索引就不可用了。

可以用建立函数索引的方式,来解决这个问题

例如:

select * from product where nvl(price,0.0)>1000.0 ;

这里,nvl(price,0.0)使用了函数,索引不能利用price字段上做的索引了

ok,我们来创建函数索引

create index index_price on product(nvl(price,0.0));


5.索引的删除

drop index 索引名

drop index idx_empname;


6.其它的

唯一索引能极大的提高查询速度,而且还有唯一约束的作用

一般索引,只能提高30%左右的速度

经常插入,修改,应在查询允许的情况下,尽量减少索引,因为添加索引,插入,修改等操作,需要更多的时间

可以在order by的字段,where的条件字段,join的关联字段添加索引

比如:

select * from table1   t1

left join table2   t2 on t1.字段A=t2.字段B

where t1.字段C = '值'

order by t1.字段D

这里,A,B,C,D字段,都应该添加索引





分享到:
评论

相关推荐

    Oracle 创建索引的基本规则

    本文将围绕Oracle创建索引的基本规则进行深入探讨,旨在帮助读者更好地理解如何根据不同的场景选择合适的索引类型,并掌握创建索引时的一些关键考虑因素。 #### 一、B-Tree索引 B-Tree(平衡树)索引是Oracle中最...

    oracle创建表,索引,表空间,触发器,schema用户,序列的Sql文

    在Oracle数据库管理中,SQL(Structured Query Language)是用于创建、...在实际应用中,根据业务需求可能还需要考虑其他因素,如分区、约束、存储过程、视图等。掌握这些基本操作对于理解和管理Oracle数据库至关重要。

    Oracle创建索引要做到三个适当.doc

    正如文档标题“Oracle创建索引要做到三个适当”所强调的,创建索引需要遵循“适当”的原则,具体包括在适当的表上、适当的列上创建适当数量的索引。以下将对这三个方面进行详细阐述,以帮助数据库管理员更好地理解...

    [Oracle]如何在亿级记录表中创建索引

    因此,在大规模数据表上创建索引时需要综合考虑多种因素。 #### 二、创建索引前的准备工作 在创建索引之前,了解表的基本结构和特性是非常重要的。这有助于确定最佳的索引策略。 ##### 1. 查看表是否为分区表及其...

    oracle 索引创建.ppt

    创建索引时,应考虑以下因素: - **选择索引列**:根据查询语句的WHERE子句频繁使用的列来选择索引列。对于经常出现在WHERE子句中的列,创建索引会提高查询效率。 - **索引类型**:根据数据类型和查询需求选择合适...

    09 oracle的索引 PPT

    Oracle数据库是世界上最广泛使用的数据库系统之一,其性能优化的一个关键因素就是索引的使用。索引可以帮助快速查找和访问数据库中的数据,显著提高查询效率。本篇将详细讲解Oracle数据库中的索引及其重要性。 一、...

    oracle的索引初步学习.doc

    虽然索引能够显著提高查询性能,但在创建索引时也需要考虑到以下几点: 1. **查询性能与维护成本的平衡**:索引能够加速查询,但也增加了插入、更新和删除操作的成本,因为这些操作不仅需要修改表中的数据,还需要...

    Oracle 分区表 分区索引

    在决定是否对表进行分区时,需要考虑以下几个因素: - **数据量大小**:当表中的数据量非常大时(通常超过2GB),分区可以帮助提高查询性能。 - **查询模式**:如果大多数查询都涉及对表的一部分数据进行操作,则...

    oracle,数据库索引

    在决定创建索引的列时,应考虑以下因素: 1. **频繁搜索的列**:提高搜索速度。 2. **主键列**:确保数据唯一性和表结构。 3. **外键列**:加速连接操作。 4. **范围查询列**:索引排序后,范围查询更高效。 5. **...

    Oracle索引机制分析

    4. **函数索引**:允许在基于函数的结果上创建索引,提高了对函数表达式查询的性能。 5. **反向键索引**:在键值顺序与自然顺序相反的情况下使用,如在降序排列的列上。 6. **分区索引**:分为本地分区索引(每个...

    oracle索引,常见索引问题

    6. **索引维护**:创建和维护索引是数据库管理员的重要任务,需要考虑查询模式、数据分布、更新频率等因素。过度使用索引可能导致插入、更新和删除操作变慢,而没有合适的索引则可能影响查询效率。 在设计数据库和...

    oracle索引机制分析

    ### Oracle索引机制分析 ...在设计索引策略时,应考虑数据的选择性、表的大小、查询模式等因素,以确保索引能够有效地支持各种查询需求。此外,还需要定期监控和调整索引,以适应数据和业务需求的变化。

    Oracle索引优化

    函数索引允许对列应用函数后再创建索引,使得查询可以使用函数结果进行查找。 了解索引的基本概念后,我们关注组合索引。组合索引是由多个列组成的索引,它可以提供更灵活的查询优化。在Oracle9i之前,只有当查询...

    oracle rac环境下索引热块的处理思路

    创建合适的索引需要考虑很多因素,例如表的结构、数据分布、查询模式等。一个好的索引可以提高查询性能,但一个坏的索引可能会降低性能。 在 Oracle RAC 环境下,索引热块争用的处理思路需要考虑到多实例并发 ...

    Oracle创建表时考虑列顺序.pdf

    Oracle数据库在创建表时,列顺序的选择确实会对性能产生...总的来说,Oracle创建表时应考虑列顺序,以减少不必要的性能开销。同时,还需要综合考虑其他因素,如索引、分区、数据分布等,以实现整体的数据库性能优化。

    创建索引对SQL语句执行的影响.pdf

    创建索引对SQL语句执行的影响是一个复杂的问题,需要考虑多种因素,包括执行计划、索引的创建、系统资源等。只有通过深入的分析和测试,我们才能真正地理解创建索引对SQL语句执行的影响,并且找到最优的解决方案。

    合理创建和使用索引 提高Oracle查询效率.pdf

    在创建索引时,需要考虑到表的结构、字段的分布情况和查询的模式等因素。只有合理地创建和使用索引,才能真正发挥索引的作用,提高查询效率。 索引的维护管理由数据库管理系统自动完成,无须用户干预。在Oracle环境...

    Oracle DBA实战索引优化

    1. **索引构建**:当创建索引时,Oracle会在索引结构中存储每一条记录的关键字值及对应的ROWID。 2. **查询过程**:当执行查询时,Oracle首先访问索引,根据索引中的关键字值查找相应的ROWID,再根据ROWID获取实际的...

    ORACLE索引介绍与高性能SQL优化

    在决定何时使用索引时,需要考虑几个因素。首先,如果查询返回的记录数较少,那么使用索引的优势会更加明显。对于排序表,如果返回记录的比例小于40%,则应该使用索引;对于非排序表,这个比例应小于7%。此外,表的...

Global site tag (gtag.js) - Google Analytics