本文主要是介绍oracle数据库索引失效的问题及解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引...
oracle数据库索引失效问题
场景
在开发中有时候遇到某个表中的列明明是创建了索引,但查询时却发现索引失效。
环境
下面是工作流activitijavascript中的两张表act_hi_procinst、act_hi_taskinst关系是一对多(一个流程包含多个流程环节),一个是历史流程表,一个是历史流程环节表。
索引失效情况及验证
(单表act_hi_procinst已经在delete_reason_列上创建了索引 )
验证一:索引列为is null 和 is not null时,索引失效
select * from act_hi_procinst t where t.delete_reason_ is not null; select * from act_hi_procinst t where t.delete_reason_ is null;
全表扫描,该列索引失效
select * from act_hi_procinst t where t.delete_reason_ ='ACTIVITI_DELETED' and rownum < 1000;
索引生效,Oracle 数据库使用索引范围扫描方式。
这种扫描方式通过索引键值的范围来定位需要的数据。
select * from act_hi_procinst t where t.delete_reason_ is not null and t.start_time_ between TO_DATE('2023-01-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and TO_DATE('2023-12-31 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and rownum < 1000
结论一
经验证索引列查询使用is null 和 is not null则该列索引失效。
验证二:索引列为 !=和 <> 时会导致该索引列失效
select * from act_hi_procinst t where t.delete_reason_ !='ACTIVITI_DELETED'; select * from act_hi_procinst t where t.delete_reason_ <>'ACTIVITI_DELETED';
结论二
经验证索引列查询使用 !=和 <> 时会导致该索引列失效
验证三:索引列用函数处理则该索引会失效
select * from act_hi_procinst t where to_char(start_time_,'YYYY')= '2023'
结论三
索引列用函数处理则该索引会失效,如字符串函数trunc,to_char,substring,to_date等函数
区别下面的sql(下面的sql走索引)
select * from act_hi_procinst t where t.start_time_ >= TO_DATE('2023-01-01 00:00:00', 'YYYY-MM-DD HH编程24:MI:SS');
验证四:索引列使用like的前置%查询,则该索引列失效。
select * frohttp://www.chinasem.cnm act_hi_procinst t where t.business_key_www.chinasem.cn like '%20230103-00001python02'
like 使用后置百分号走索引
结论四
经验证索引列使用like的前置%查询时会导致该索引列失效,但是使用了ike的后置%则会走索引
验证五:范围索引查询和等值索引查询同时存在,则范围索引失效
其中start_time_创建有普通索引,delete_reason_字段也创建了普通索引
- SQL一:
select * from act_hi_procinst t where t.start_time_ between TO_DATE('2023-01-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and TO_DATE('2023-12-31 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and t.delete_reason_ ='ACTIVITI_DELETED' and rownum < 1000;
- SQL二:
select * from act_hi_procinst t where t.start_time_ >= TO_DATE('2023-01-01 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and t.start_time_<= TO_DATE('2023-12-31 00:00:00', 'YYYY-MM-DD HH24:MI:SS') and t.delete_reason_ ='ACTIVITI_DELETED' and rownum < 1000
结论五
范围索引查询和等值索引查询同时存在,则范围索引失效
注:上面的查询sql中加 rownum < 1000的目的主要是数据量太大,这里只是要验证一下查询是否走索引列
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。
这篇关于oracle数据库索引失效的问题及解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!