为什么根据最新的入机时间范围不能使用索引了

SELECT *
  FROM (SELECT row_.*, ROWNUM rownum_
          FROM (SELECT DISTINCT (em.endorno), gmm.operatedate, eh.inputdate
                           FROM guendormain em,
                                 guendorrisk er,
                                 guendorendorheadeh,
                                 gomaterialmain gmm
                          WHERE em.endorno = er.endorno
                            AND er.endorno = eh.endorno
                            AND gmm.certino(+) = em.endorno
                            AND (er.uwyear = '2010')
                            AND (eh.validind = '1')
                            AND (eh.inputdate >=
                                    TO_DATE ('2011-03-31',
                                             'YYYY-MM-DD HH24:MI:SS'
                                            )
                                )
                            AND (((((eh.companycode LIKE '020701%')))))
                       ORDER BY gmm.operatedate, eh.inputdate) row_
         WHERE ROWNUM <= 15)
 WHERE rownum_ > 0

 

这个语句最近很奇怪,都不使用索引了。在inputdate 及companycode上可是有索引存在的,以前的效果也不错的。可最近不知是怎么了。

尝试将日期改为5月31日进行查询,也不行,将公司代码改为0207000001,居然可以了,但是单独使用日期的话,是不行的,因此怀疑是日期在cbo估算的时候出现了问题。将日期的》=改为=。可以使用索引。

为了测试,按照该表的结果建立了一个副本表,并创建类似的索引。

创建好后,索引可以使用,但是一旦用统计函数进行详细的统计信息收集,索引又不可使用。查出eh.inputdate >=
                                    TO_DATE ('2011-03-31',
                                             'YYYY-MM-DD HH24:MI:SS'
                                            )
的值,看看到底有多少日期超过了这个时期,可是按照业务逻辑来讲,这是不允许存在的情况啊。

查出来果然有很多inputdate列存在日期为9999-12-31 23:59:59的值oracle在计算成本的时候会误认为比条件日期大的值数量较多。所以不会使用在入机时间上的索引。如果没有理解错,9999-12-31 23:59:59为避免该列的空值而设定的默认值,而且是应该最近才修改的。但是为了保证该业务的效率,能否将该默认值改小,比如1111-12-31 23:59:59.避免oracle的错误判断。

所以,表设计是,避免空值是很重要的,但是默认值的设定也是很有讲究的,否则问题多多啊。

 

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/288166/viewspace-691270/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/288166/viewspace-691270/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值