在Oracle中合理创建数据库的索引

作者&投稿:沙平 (若有异议请与网页底部的电邮联系)
~

  在Oracle数据库中 创建索引虽然比较简单 但是要合理的创建索引则比较困难了 笔者认为 在创建索引时要做到三个适当 即在适当的表上 适当的列上创建适当数量的索引 虽然这可以通过一句话来概括优化的索引的基本准则 但是要做到这一点的话 需要数据库管理员做出很大的努力 具体的来说 要做到这个三个适当有如下几个要求

   一 根据表的大小来创建索引

  虽然给表创建索引 可以提高查询的效率 但是数据库管理员需要注意的是 索引也需要一定的开销的 为此并不是说给所有的表都创建索引 那么就可以提高数据库的性能 这个认识是错误的 恰恰相反 如果不管三七二十一 给所有的表都创建了索引 那么其反而会给数据库的性能造成负面的影响 因为此时滥用索引的开销可能已经远远大于由此带来的性能方面的收益 所以笔者认为 数据库管理员首先需要做到 为合适的表来建立索引 而不是为所有的表建立索引

  一般来说 不需要为比较小的表创建索引 如在一个ERP系统的数据库中 department表用来存储企业部门的信息 一般企业的部分也就十几个 最多不会超过一百个 这 条记录对于人来说 可能算是比较多了 但是对于计算机来说 这给他塞塞牙缝都还不够 所以 对类似的小表没有必要建立索引 因为即使建立了索引 其性能也不会得到很大的改善 相反索引建立的开销 如维护成本等等 要比这个要大 也就是说 付出的要比得到的多 显然违反常理

  另外 就是对于超大的表 也不一定要建立索引 有些表虽然比较大 记录数量非常的多 但是此时为这个表建立索引并一定的合适 如系统中有一张表 其主要用来保存数据库中的一些变更信息 往往这些信息只给数据库管理员使用 此时为这张表建立索引的话 反而不合适 因为这张表很少用到 只有在出问题的时候才需要查看 其次其即使查看 需要查询的纪录也不会很多 可能就是最近一周的更新记录等等 对于对于一些超大的表 建立索引有时候往往不能够达到预计的效果 而且在打表上建立索引 其索引的开销要比普通的表大的多 那么到底是否给大表建立索引呢?笔者认为 主要是看两个方面的内容 首先是需要关注一下 在这张大表中经常需要查询的记录数量 一般来说 如果经常需要查询的数据不超过 %到 %的话 那就没有必要为其建立索引的必要 因为此时建立索引的开销可能要比性能的改善大的多 这个比例只是一个经验的数据 如果数据库管理员需要得出一个比较精确的结论 那么就需要进行测试分析 即数据库管理员需要测试一下全表扫描的时间 看看其是否比建立索引后的查询时间要长或者短 如果是长的话 则说明有建立索引的必要 但是如果没有的话 则说明还是全表扫描速度来的快 此时也就没有必要建立索引了

  总之 在考虑是否该为表建立索引时 一般来说小表没有建立索引的必要 而对于打表的话 则需要进行实际情况实际分析 简单一点的 可以根据大致的比率来确定 如果要精确一点的 则可以进行全表扫描性能分析 以判断建立索引后是否真的如预期那样改善了数据库性能

   二 根据列的特征来创建索引

  列的特点不同 索引创建的效果也不同 数据库管理员需要了解为哪些列创建索引可以起到事倍功半的效果 同时也需要了解为哪些列创建索引反而起到的是事倍功半的效果 这有利于他们了解到底给为怎么样的字段建立索引

  根据笔者的经验 往往为如下特征的列创建索引能够起到比较明显的效果 如对于一些重复内容比较少的列 特别是对于那些定义了唯一约束的列 在这些列上建立索引 往往可以起到非常不错的效果 如对于一些null值的列与非Null值的列混合情况下 如果用户需要经常查询所有的非Null值记录的列 则最好为其设置索引 如果经常需要多表连接查询 在用与连接的列上设置索引可以达到事半功倍的效果

  可见 索引设置的是否恰当 不仅跟数据库设计架构有关 而且还跟企业的经济业务相关 为此 对于一些套装软件 虽然一开始数据库管理员已经做了索引的优化工作 但是随着后来经济数据的增加 这个索引的效果会越来越打折扣 这主要是因为记录的表化影响到了索引优化的效果 所以笔者建议各位数据库管理员 即使采用的是大牌软件公司的套装软件 也需要隔一段时间 如一年 对数据库的索引进行优化 该去掉的去掉 该调整的调整 以提高数据库的性能

  如在数据库中有一张表是用来保存用户信息的 其中有个字段身份证号码 这是一个唯一的字段 在数据库设计时 给这个字段创建了索引 但是当这个数据库投入使用之后 用户不怎么输入用户的身份证号码 而且平时也基本不按这个号码来进行查询 当记录月来月多时 这个身份证号码上的索引字段不但不能够改善数据库的查询性能 反而成了鸡肋 对于这些有很多NULL值的列 而且不会经常查询所有的非NULL值记录的列 数据库管理员要下决心 即使清除这些列上的索引

  所以说索引的优化与调整是一个动态的过程 并不是说数据库设计好之后就不需要经过调整 数据库管理员往往需要根据记录的变化情况 来进行适当的变更 以提高索引的效果

   三 在一个表上创建多少索引合适?

  虽然说 在表上创建索引的数量没有限制 但是决不是越多越好 也就是说 在创建索引这项事情上 + 〉 往往不成立 有时候 创建索引越多 其可能会得到适得其反的效果 那么在一个表上 到底给创建多少索引合适呢?这个没有一个明确的标准 而是需要数据库管理员根据实际的用途以及数据库中记录的情况 来进行判断

  通常来说 表的索引越多 其查询的速度也就越快 但是 表的更新速度则会降低 这主要是因为表的更新(如往表中插入一条记录)速度 反而随着索引的增加而增加 这主要是因为 在更新记录的同时需要更新相关的索引信息 为此 到底在表中创建多少索引合适 就需要在这个更新速度与查询速度之间取得一个均衡点 如对于一些数据仓库或者决策型数据库系统 其主要用来进行查询 相关的记录往往是在数据库初始化的时候倒入 此时 设置的索引多一点 可以提高数据库的查询性能 同时因为记录不怎么更新 所以索引比较多的情况下 也不会影响到更新的速度 即使在起初的时候需要导入大量的数据 此时也可以先将索引禁用掉 等到数据导入完毕后 再启用索引 可以通过这种方式来减少索引对数据更新的影响 相反 如果那些表中经常需要更新记录 如一些事务型的应用系统 数据更新操作是家常便饭的事情 此时如果在一张表中建立过多的索引 则会影响到更新的速度 由于更新操作比较频繁 所以对其的负面影响 要比查询效率提升要大的多 此时就需要限制索引的数量 只在一些必要的字段上建立索引

  笔者在平时数据库优化时 往往会根据这些表的用途来为列设置索引 可以查询相关的动态视图 看看对于这张表的操作 是更新操作(包括更新 删除 插入等等)占的比例大 还是查询操作占的比例大 当过多的索引已经影响到更新操作的速度时 则数据库管理员就需要先禁用某些索引 以提高数据库的性能

lishixinzhi/Article/program/Oracle/201311/18407




Oracle面试题(基础篇)
8). 合理使用事务,合理设置事务隔离性 数据库的数据操作比较消耗数据库资源的,尽量使用批量处理,以降低事务操作次数 7. Oracle中字符串用什么符号链接? Oracle中使用 || 这个符号连接字符串 如‘abc’ || ‘d’ 8. Oracle分区是怎样优化数据库的`? Oracle的分区可以分为:列表分区、范围分区、散列分区、复合分区...

我想知道 oracle一个表中的上千万条,如何使查询按时间来达到更快的...
1、是否按时间分区,要看你的查询条件了,如果查询的都是有明确的日期,那当然可以分区,这样在查询过程中oracle只会在符合条件的分区中查询数据相当于减少了查询数量。2、具体放在多少个表空间里这个是和你的硬件有直接关系的。如果你只有一块硬盘,那不论你分多少个表空间,在读写时也只有一个driver...

ORACLE 常用操作语句规范和注意事项
v. 如果使用到了临时表,在存储过程的最后务必将所有的临时表显式删除,先truncate table,然后drop table,这样可以避免系统表的较长时间锁定。vi. 慎用大的临时表与其他大表的连接查询和修改,减低系统表负担,因为这种操作会在一条语句中多次使用tempdb的系统表。d) 合理的算法使用:根据上面已提到的...

Oracle等数据库数据量特别大的时候怎样从程序和SQL语句方面优化使查询...
2、创建索引,创建合适的索引可以大大提高查询速度。但是你的这张大表如果会频繁的进行update、insert等操作,索引会导致这些操作变慢。就有可能需要进行动态索引的使用。3、优化复杂SQL;对复杂的SQL进行合理的优化,这个有时候也需要根据你的数据情况来优化,可以参考一些SQL语句优化方面的文档。

oracle与sqlserver区别
ORACLE存储结构 在ORACLE里有两个块参数PCTFREE(填充因子)和PCTUSED(复用因子) 可控制块确定块本身何时有 何时没有足够的空间接受新信息(对块的存储情况的分析机制) 这样可降低数据行连接与行迁移的可能性 块的大小可设置(OLTP块和DSS块) 在ORACLE中 将连续的块组成区 可动态分配区(区的分配可以是等额的也可以...

oracle如何完成数据库优化
这两条查询语句实现的结果是相同的,但是执行语句A的时候,ORACLE会对整个emp表进行扫描,没有使用建立在emp表上的deptno索引,执行语句B的时候,由于在子查询中使用了联合查询,ORACLE只是对emp表进行的部分数据扫描,并利用了deptno列的索引,所以语句B的效率要比语句A的效率高一些。 2、2、选择联合查询的联合次序。考虑...

Oracle高级的安全特性考虑了哪些因素
影响Oracle系统性能的参数:影响Oracle数据性能的因素有很多,比如:操作系统,CPU 性能,内存分配不合理,Oracle 配置,I\/O 冲突,网络速度低以及SQL使用常见错误等等都会影响数据库的性能。1)操作系统:Oracle 数据库服务器很大程度上依赖于运行服务器的操作系统,操作系统配置不合理会直接降低Oracle性能;2)...

Oracle中的统计信息是做什么用的?有什么用处
统计信息为了让oracle 的SQL优化器了解数据信息 包括数据量的多少和分布,以便SQL优化器 CBO能够获得较佳的执行计划,较好的执行计划 意味着oracle对于不同的SQL使用合理的访问路径和Join方式,简而言之是得到更好的性能。askmaclean oracle

oracle 对于多个大表关联操作如何优化速度?
2、最大数据量的表放在最前,最小的表放在最后面。sql是从最后面开始反向解析的。3、其次是要把最有效缩小范围的条件放到sql末尾去。尤其是主键或者索引字段的条件。4、保证你sql的算法合理性。保证复杂度和空间度的合理性。5、必要时候使用存储过程。提升30%-40%的速度 6、建议你分页读取不要一下...

oracle数据库中,Oracle Net客户端如何配置??
当我们建立了Oracle数据库后,必须合理地配置监听程序和网络服务名后,客户应用才能访问我们的数据库。所以服务器端必须配置监听程序,而网络服务名在客户端跟服务器端都可以配置。看如下说明:1。服务器端的监听程序用于接收客户端的连接请求。在建立了Oracle数据库之后,为了使得客户应用可以访问特定数据库,...

承德市19556808576: 怎样在Oracle中合理创建数据库的索引?
荡肿藤黄: 在Oracle数据库中,创建索引虽然比较简单.但是要合理的创建索引则比较困难了.笔者认为,在创建索引时要做到三个适当,即在适当的表上、适当的列上创建适当数量...

承德市19556808576: 如何合理创建Oracle数据库索引的3个要求 -
荡肿藤黄: 如何合理创建Oracle数据库索引的3个要求:在Oracle数据库中,创建索引虽然比较简单.但是要合理的创建索引则比较困难了.笔者认为,在创建索引时要做到三个适当,即在适当的表上、适当的列上创建适当数量的索引.虽然这可以通过一...

承德市19556808576: 如何在ORACLE数据库的字段上建立索引 -
荡肿藤黄: Oracle中建立索引,会提高查询速度:create index 索引名 on 表名(列名); 例如:create index index_userid on tbl_detail(userid);

承德市19556808576: oracle中怎么建立和使用索引 -
荡肿藤黄: 在程序中,oracle优化器在认为索引效率更高时,会自动调用索引. 也可以显式调用索引: select /*+index(A,索引名)*/ * from A where b='',c='';

承德市19556808576: 如何创建分区的oracle空间索引 -
荡肿藤黄: 方法如下:Oracle中建立索引,会提高查询速度: create index 索引名 on 表名(列名); 例如: create index index_userid on tbl_detail(userid); 如何找数据库表的主键字段的名称? SELECT * FROM user_constraints WHERE CONSTRAINT_...

承德市19556808576: Oracle数据库中怎样选择合适索引类型 -
荡肿藤黄: 索引的相关作用就好比字典的目录.根据字典的目录,我们就可以快速的找到我们需要的相关条目.数据库的作用也是.通过Oracle数据库的索引,我们就可以可以迅速的来定位记录的位置,而不必去定位整个表.虽然说,在表中是否创建索引...

承德市19556808576: 如何提升Oracle数据库搜索效率 -
荡肿藤黄: 需要用索引来解决,索引的创建规则如下: 1、表的主键、外键必须有索引; 2、数据量超过300的表应该有索引; 3、经常与其他表进行连接的表,在连接字段上应该建立索引; 4、经常出现在Where子句中的字段,特别是大表的字段,应该建...

承德市19556808576: Oracle创建索引SQL简单的例子,在表中的指定字段和如何使用索引呢? -
荡肿藤黄: create index index_name on table_name(column_name) ; 只要你查询使用到建了索引的字段,一般都会用到索引. --创建表 create table aaa( a number, b number);--创建索引 create index idx_a on aaa (a);--使用索引 select * from aaa where a=1; 这句查询就会使用索引 idx_a

承德市19556808576: 在Oracle 10g中创建数据库的方法有哪些?它们分别由哪些优点和缺点? -
荡肿藤黄: 1.创建向导,界面化的,一步一创建,直观2.语句创建,方便快捷

承德市19556808576: oracle中如何新建一个数据库 -
荡肿藤黄: oracle里面不叫数据库了,叫创建一个命名空间 创建表空间的语法是: CREATE TABLESPACE tablespacename DATAFILE 'filename' [SIZE integer [K|M]] [AUTOEXTEND [OFF|ON]]; --创建用户 create user scce identified by 123; --授权 grant connect to scce; grant resource to scce; grant create synonym to scce; --连接 SQL> conn scce/123;

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网