ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 为什么根据最新的入机时间范围不能使用索引了

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

原创 Linux操作系统 作者:lsl031 时间:2011-03-30 08:35:43 0 删除 编辑

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/,如需转载,请注明出处,否则将追究法律责任。

上一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2009-03-24

  • 博文量
    56
  • 访问量
    799651