ORACLE 查询不走索引的原因分析,解决办法通过强制索引或动态执行SQL语句提高查询速度
(一)索引失效的原因分析:
- <>或者单独的>,<,(有时会用到,有时不会)
- 有时间范围查询;oracle 时间条件值范围越大就不走索引
- like "%_" 百分号在前.
- 表没分析(统计信息最好定期收集,以业务的不同确定不同的收集周期,在新增的索引有可能没有收集 ,那么就会导致索引失效)
解决方法:
分析方法有一下几种:
analyze table t1 compute statistics fortable; --针对表收集信息
analyze table t2 compute statistics for allcolumns; --针对表字段收集信息
analyze table t3 compute statistics for all indexescolumns; --收集索引字段信息
analyze table t4 computestatistics; --收集表,表字段,索引信息
analyze table t5 compute statistics for allindexes; --收集索引信息
analyze table t6 compute statistics for table for all indexesfor allcolumns; --
--收集表,索引,表字段信息
- 单独引用复合索引里非第一位置的索引列.
- 字符型字段为数字时在where条件里不添加引号.
- 对索引列进行运算.需要建立函数索引.
- not in ,not exist.
- 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。
- 索引失效。
- 基于cost成本分析(Oracle因为走全表成本会更小):查询小表,或者返回值大概在10%以上;
解决办法:
在这种条件下 oracle会认为索引更占资源,就默认不走索引了。这种情况如果觉得索引快的,通过强制索引提高查询速度
select /*+INDEX(t IDEX_HZYB_JSJL_BDJSRQ)*/ from hzyb_jsjl t
where BDJSRQ >TO_DATE('','');
其中T是 表名 IDEX_HZYB_JSJL_BDJSRQ 是表的索引
- 有时都考虑到了 但就是不走索引,drop了从建试试在
- B-tree索引 is null不会走,is not null会走,(B树索引示例:create index random_empno_idx on test_random(empno);)
- 位图索引 is null,is not null 都会走(位图索引示例:create bitmap index normal_empno_bmx on test_normal(empno);)
- 联合索引 is not null 只要在建立的索引列(不分先后)都会走,(组合索引示例:SQL> create index indx_t on t(object_type,object_name);)
in null时 必须要和建立索引第一列一起使用,当建立索引第一位置条件是is null 时,其他建立索引的列可以是is null(但必须在所有列都满足is null的时候),或者=一个值;
当建立索引的第一位置是=一个值时,其他索引列可以是任何情况(包括is null =一个值),以上两种情况索引都会走。其他情况不会走。
(二)通过动态执行SQL提高查询COUNT()执行速度
var_strquery1 := 'SELECT COUNT(1)';
var_strquery := 'FROM r_sn_link k
LEFT JOIN mfworkstatus s
ON k.p_sn = s.sysserialno
LEFT JOIN mfworkorder r
ON k.wo = r.workorderno
WHERE 1 = 1 '; IF var_smt_wo IS NOT NULL OR var_smt_wo <> ''
THEN
var_strquery := var_strquery || ' AND k.wo =''' || var_smt_wo || '''';
END IF; IF var_dip_wo IS NOT NULL OR var_dip_wo <> ''
THEN
var_strquery :=
var_strquery || ' AND s.workorderno =''' || var_dip_wo || '''';
END IF; IF var_skuno IS NOT NULL OR var_skuno <> ''
THEN
var_strquery :=
var_strquery
|| ' AND (r.skuno ='''
|| var_skuno
|| ''''
|| 'OR s.skuno ='''
|| var_skuno
|| ''''
|| ')';
END IF; IF var_sn_code IS NOT NULL OR var_sn_code <> ''
THEN
var_strquery :=
var_strquery || ' AND k.sn_code = ''' || var_sn_code || '''';
END IF; IF var_p_sn IS NOT NULL OR var_p_sn <> ''
THEN
var_strquery := var_strquery || 'AND k.p_sn =''' || var_p_sn || '''';
END IF; IF var_from_datetime IS NOT NULL OR var_from_datetime <> ''
THEN
var_strquery :=
var_strquery
|| ' AND k.work_time >= to_date('
|| var_from_datetime
|| ',''yyyy/mm/dd hh24:mi:ss'')';
END IF; IF var_to_datetime IS NOT NULL OR var_to_datetime <> ''
THEN
var_strquery :=
var_strquery
|| ' AND k.work_time <= to_date('
|| var_to_datetime
|| ',''yyyy/mm/dd hh24:mi:ss'')';
END IF; --动态执行查询语句返回记录数
EXECUTE IMMEDIATE var_strquery1 || var_strquery INTO var_rowcount;
ORACLE 查询不走索引的原因分析,解决办法通过强制索引或动态执行SQL语句提高查询速度的更多相关文章
- 解决乱码的方法是,在执行SQL语句之前,将MySQL以下三个系统参数设置为与服务器字符集character-set-server相同的字符集
character-set-server/default-character-set:服务器字符集,默认情况下所采用的. character-set-database:数据库字符集. characte ...
- Hibernate执行SQL语句实现查询修改功能!
今天玩Hibernate时突然就想写写SQL语句查询... DAO : //查询 public List<?> createSqlQueryList(final String queryS ...
- PHP获取MySQL执行sql语句的查询时间
//计时开始 runtime(); //执行查询 mysql_query($sql); //计时结束. echo runtime(1); //计时函数 function runtime($mode=0 ...
- [转]ORACLE 动态执行SQL语句
本文转自:http://zhaisx.iteye.com/blog/856472 Oracle 动态SQLOracle 动态SQL有两种写法:用 DBMS_SQL 或 execute immediat ...
- ORACLE 动态执行SQL语句
本文转自 http://zhaisx.iteye.com/blog/856472 Oracle 动态SQL Oracle 动态SQL有两种写法:用 DBMS_SQL 或 execute immedia ...
- (转载)PHP怎么获取MySQL执行sql语句的查询时间
(转载自CSDN) 方法一: //计时开始 runtime(); //执行查询 mysql_query($sql); //计时结束. echo runtime(1); //计时函数 function ...
- Oracle常见死锁发生的原因以及解决方法
Oracle常见死锁发生的原因以及解决办法 一,删除和更新之间引起的死锁 造成死锁的原因就是多个线程或进程对同一个资源的争抢或相互依赖.这里列举一个对同一个资源的争抢造成死锁的实例. Oracle 1 ...
- 解决Mysql搭建成功后执行sql语句报错以及区分大小写问题
刚搭建完mysql 8.0以后会: 一.表区分大小写, 二.执行正确的sql语句成功且会报:[Err] 1055 - Expression #1 of ORDER BY clause is not i ...
- oracle 索引失效原因及解决方法
oracle 索引失效原因及解决方法 2010年11月26日 星期五 17:10 一.以下的方法会引起索引失效 1,<>2,单独的>,<,(有时会用到,有时不会)3,like ...
随机推荐
- sql中对数值四舍五入取小数点后两位数字
用:cast(value as decimal(10,2)) 来实现.
- [bzoj1131][POI2008]Sta_树形dp
Sta bzoj-1131 POI-2008 题目大意:给定一棵n个点的树,求一个根,使得深度和最大. 注释:$1\le n \le 10^6$. 想法:扭一扭即可. 扭的时候看看这个点当没当过根. ...
- BZOJ——T 1800: [Ahoi2009]fly 飞行棋
Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1767 Solved: 1395[Submit][Status][Discuss] Descripti ...
- 51nod——T1267 4个数和为0
https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1267 题目描述 给出N个整数,你来判断一下是否能够选出4个数,他们的和 ...
- 洛谷 P1491 集合位置
P1491 集合位置 题目描述 每次有大的活动,大家都要在一起“聚一聚”,不管是去好乐迪,还是避风塘,或者汤姆熊,大家都要玩的痛快.还记得心语和花儿在跳舞机上的激情与释放,还记得草草的投篮技艺是如此的 ...
- 动态加入的HTML的自己主动渲染
这两天在写一个用EasyUI的前台,遇到动态向Layout加入HTML内容时没有自己主动渲染的问题.查了一下网上的资料后得以解决.详细例如以下: $("#content").htm ...
- pthread_rwlock pthread读写锁
原文: http://www.cnblogs.com/diegodu/p/3890450.html 使用读写锁 配置读写锁的属性之后,即可初始化读写锁.以下函数用于初始化或销毁读写锁.锁定或解除锁定读 ...
- 全部对于Unity3D中 NGUI 触发事件的监听方法
NGUI事件的种类非常多.比方点击.双击.拖动.滑动等等,他们处理事件的原理差点儿万全一样,本文仅仅用button来举例. 方法一.直接监听事件 把以下脚本直接绑定在button上.当button点击 ...
- oracle加入联合主键
alter table tablename add constraint unionkeyname primary key (column1,column2); 上面语句中: tablename为要加 ...
- pat解题报告【1082】
1082. Read Number in Chinese (25) 时间限制 400 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard ...