oracle 强制索引无效,oracle强制索引失效

如果两个或以上索引具有相同的等级,你可以强制命令ORACLE优化器使用其中的一个(通过它,检索出的记录数量少) .

举例:

SELECT ENAME

FROM EMP

WHERE EMPNO = 7935

AND DEPTNO + 0 = 10    /*DEPTNO上的索引将失效*/

AND EMP_TYPE || ‘’ = ‘A’ /*EMP_TYPE上的索引将失效*/

这是一种相当直接的提高查询效率的办法. 但是你必须谨慎考虑这种策略,一般来说,只有在你希望单独优化几个SQL时才能采用它.

这里有一个例子关于何时采用这种策略,

假设在EMP表的EMP_TYPE列上有一个非唯一性的索引而EMP_CLASS上没有索引.

SELECT ENAME

FROM EMP

WHERE EMP_TYPE = ‘A’

AND EMP_CLASS = ‘X’;

优化器会注意到EMP_TYPE上的索引并使用它. 这是目前唯一的选择. 如果,一段时间以后, 另一个非唯一性建立在EMP_CLASS上,优化器必须对两个索引进行选择,在通常情况下,优化器将使用两个索引并在他们的结果集合上执行排序及合并. 然而,如果其中一个索引(EMP_TYPE)接近于唯一性而另一个索引(EMP_CLASS)上有几千个重复的值. 排序及合并就会成为一种不必要的负担. 在这种情况下,你希望使优化器屏蔽掉EMP_CLASS索引.

用下面的方案就可以解决问题.

SELECT ENAME

FROM EMP

WHERE EMP_TYPE = ‘A’

AND EMP_CLASS||’’ = ‘X’;

标签:ENAME,优化,索引,EMP,oracle,失效,TYPE,CLASS

来源: https://www.cnblogs.com/fanweisheng/p/11124968.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle强制索引没有效果时,可能有以下几个原因: 1. 索引选择不当:强制索引是通过强制查询优化器使用某个索引来执行查询。但是如果选择的索引不合适,可能会导致效果不佳。索引的选择应该根据查询的条件和表的大小来进行。 2. 统计信息不准确:查询优化器使用统计信息来估计查询的成本和选择最合适的执行计划。如果统计信息不准确或者过时,就会导致查询优化器选择错误的索引或执行计划。 3. 强制索引被覆盖:如果强制索引被其他索引所覆盖,那么查询优化器可能会选择覆盖索引来执行查询,而忽略强制索引。 4. 数据冗余:如果表中的数据冗余较多,那么强制索引可能无法提供明显的性能提升效果。 解决这些问题的方法有: 1. 确保选择合适的索引:根据查询的条件和表的大小,选择合适的索引。通过使用索引提示或者修改查询语句来强制使用正确的索引。 2. 更新统计信息:定期更新表的统计信息,使得查询优化器能够选择正确的索引和执行计划。 3. 检查是否有覆盖索引:使用explain plan等工具来检查查询的执行计划,确保强制索引没有被其他索引所覆盖。 4. 优化数据结构:如果表中的数据冗余较多,考虑对表的数据进行优化,减少冗余数据的存储。 总而言之,当Oracle强制索引没有效果时,可以通过选择合适的索引、更新统计信息、检查覆盖索引和优化数据结构来解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值