深入理解Oracle索引(18):函数索引的陷阱以及如何避免索引被污染
来源:互联网 发布:斯拉夫人知乎 编辑:程序博客网 时间:2024/05/16 18:25
使用函数索引一定要注意在函数代码变更后重建函数索引、否则、Oracle将返回错误结果但不给提示
测试如下:
hr@ORCL> drop table t purge;Table dropped.hr@ORCL> create table t (x number,y varchar2(30));Table created.hr@ORCL> insert into t select rownum,rownum||'a' from dual connect by rownum<1000;999 rows created.hr@ORCL> edWrote file afiedt.buf 1 create or replace function f_david(p_value varchar2) return varchar2 2 deterministic is 3 begin 4 return p_value; 5* end; 6 7 /Function created.hr@ORCL> create index idx_f_david_t on t (f_david(y));Index created.hr@ORCL> exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false);PL/SQL procedure successfully completed.hr@ORCL> select * from t where f_david(y)='8a'; X Y---------- ------------------------------ 8 8ahr@ORCL> edWrote file afiedt.buf 1 create or replace function f_david(p_value varchar2) return varchar2 2 deterministic is 3 begin 4 return p_value||'b'; 5* end;hr@ORCL> /Function created./* 此时的函数 f_david 已经不是我们所认识的那个了、但是查询依然如故!!!*/hr@ORCL> select * from t where f_david(y)='8a'; X Y---------- ------------------------------ 8 8a/* 索引重建查询没有记录、这才是我们要的正确结果*/hr@ORCL> drop index idx_f_david_t;Index dropped.hr@ORCL> create index idx_f_david_t on t (f_david(y));Index created.hr@ORCL> exec dbms_stats.gather_table_stats(ownname=>'HR',tabname=>'T',estimate_percent=>100,cascade=>TRUE,no_invalidate=>false);PL/SQL procedure successfully completed.hr@ORCL> select * from t where f_david(y)='8a';no rows selected
㈡ 避免索引被污染
这里给出 2 条意见、
① 不要在字段前增加函数
如:
to_char(start_time,'yyyy.mm.dd') between '2013.06.06' and '2013.06.10'
和
start_time between to_date('2013.06.06','yyyy.mm.dd') and to_date('2013.06.10','yyyy.mm.dd')
任何时候都应该是第二种!!!
② 不要把字段嵌入到表达式中
如:
start_time + 7 < sysdate;
和
start_time < sysdate - 7
By David Lin
2013-06-06
Good Luck
- 深入理解Oracle索引(18):函数索引的陷阱以及如何避免索引被污染
- 深入理解Oracle索引(18):函数索引的陷阱以及如何避免索引被污染
- oracle的索引陷阱
- oracle自定义函数索引陷阱
- oracle索引-函数索引
- Oracle索引的理解
- 深入探讨Oracle函数索引
- 深入理解Oracle索引(15):日期转换函数的格式参数大小写规则对函数索引的影响
- oracle避免限制索引
- 深入理解Oracle索引(8):如何进行索引监控分析和优化
- 深入理解Oracle索引(3):唯一索引和ROWID
- 深入理解Oracle索引(13):位图连接索引基础介绍
- 深入理解Oracle索引(24):B*Tree 索引小结
- 如何创建oracle函数索引
- oracle索引:B*树索引、位图索引(bitmap)、基于函数的索引、应用域索引
- 深入理解Oracle索引(4):optimizer_index_cost_adj详解
- Oracle中B-TREE索引的深入理解
- Oracle 复合索引的理解
- 完备匹配下的最大权匹配-KM算法的一般模板
- python 3.3 摸拟登录 小例
- 10、C语言中指向由M个元素组成的一维数组的指针。
- Windows 7安装字体快捷方式实例
- Fragment的onCreate跟onCreateView的区别
- 深入理解Oracle索引(18):函数索引的陷阱以及如何避免索引被污染
- 11、C语言中字符数组和指针字符串的指针变量
- 轻松去除Windows 7快捷方式箭头
- 12、C语言。指向(只有一个字符的字符串、字符变量、一个字符)的指针变量的相同与区别
- MongoDB008 查询(一)
- 13、C语言中动态内存分配与指向它的指针变量
- Windows7激活信息备份方法 源于Vista的方法
- 14-1
- UVa 10391 - Compound Words 字符串hash