oracle联合查询索引失效
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle联合查询索引失效相关的知识,希望对你有一定的参考价值。
SELECT COUNT(1)
FROM DN_PRODUCT PU1,DN_PRODUCT_REQUEST PUR
where PU1.CLIENT_ID = '102101000004'
SELECT COUNT(1)
FROM DN_PRODUCT PU1
where PU1.CLIENT_ID = '102101000004'
SELECT COUNT(1)
FROM DN_PRODUCT_REQUEST PU1
where PU1.CLIENT_ID = '102101000004'
上面单独查询索引生效,但是联合查询后索引失效了,查询慢,配置是服务器级别的,这是啥问题?
ID都是唯一索引,CLIENT_ID是位图索引,CLIENT_ID值基本是一样的,2张表各50W,
写错了,这这样:
SELECT COUNT(1)
FROM DN_PRODUCT PU1,DN_PRODUCT_REQUEST PUR
where PU1.CLIENT_ID = PUR.CLIENT_ID
FROM DN_PRODUCT PU1,DN_PRODUCT_REQUEST PUR
where PU1.CLIENT_ID = '102101000004'
DN_PRODUCT和DN_PRODUCT_REQUEST字段没有关联,生成笛卡尔积了追问
SELECT COUNT(1)
FROM DN_PRODUCT PU1,DN_PRODUCT_REQUEST PUR
where PU1.CLIENT_ID = PUR.CLIENT_ID
oracle如何避免查询数据的时候索引失效
oracle可以使用强制索引,举个例子比如在条件诸多的sql中为了确保优先正确的使用最高效的索引可以这样写
select /*+index(a,index_name)*/ * from table_name a where col_a=? and col_b=? and col_c=? and ...;
注意() 里面的a如果表有别名要用别名如果没有就用表名,这样就会强制使用你想要用的索引了。 参考技术A 索引失效会有很多中情况了,比如like or <>等这些都可以导致索引失效,还有隐式的转换,比如数据库里是字符,而你写的时候没有带引号,会有一个隐式的转换,也会导致索引失效,还有在列上的函数也会使索引失效,如果在该列上经常会使用函数,那么建一个函数索引会比较理想。 参考技术B 要看是否失效,你可以对建立索引的表进行analyze分析先,具体语句是
analyze table **** compute statistics;如果有失效索引会提示错误
以上是关于oracle联合查询索引失效的主要内容,如果未能解决你的问题,请参考以下文章
MySQL 进阶 索引 -- 索引使用原则(验证索引效率最左前缀法则范围查询索引失效情况SQL提示覆盖索引前缀索引单列索引与联合索引)索引设计原则
MySQL 进阶 索引 -- 索引使用原则(验证索引效率最左前缀法则范围查询索引失效情况SQL提示覆盖索引前缀索引单列索引与联合索引)索引设计原则