Oracle Index 和null 研究
来源:互联网 发布:网络编程能自学么 编辑:程序博客网 时间:2024/05/22 06:28
Indexing null values
安装关系数据库理论, null表示未知,Oracle b-tree index是不包含null的。考虑如下表:
create table tt (t_id number, t_name varchar2(10));create index tt_idx on tt(t_name);
select * from tt where t_name is null是不会使用index scan的,这经常会造成性能问题。
解决办法就是:创建一个函数索引,并在select 中包含该函数,如:
create index tt_idex on tt( nvl(t_name), 1);select * from tt where nvl(t_name,1)=1;
从11g开始有另一个方法:
create index tt_idx on tt(t_name asc, 1);这里1可以是任意数字或字母。而这时,select语句的谓词不需要更改,还是t_name is null.
Uniqueness and null
drop index tt_idx;create unique index tt_idx on tt(t_name);insert into tt values(1, null);commit;insert into tt values(1, null);commit;这段SQL可以执行成功。这是因为null不被索引包含。
create table ttt2 (tt2_id number, tt21 varchar2(10), tt22 varchar2(10));create unique index ttt2_idx on ttt2(tt21, tt22);--Successfulinsert into ttt2 values(1, null, null);insert into ttt2 values(1, null, null);commit;--Failinsert into ttt2 values(1, '1', null);insert into ttt2 values(1, '1', null);commit;第二个事务会失败。因为null不被索引包含, 两个'1'就是重复值!
Conditional uniqueness
假如有需求:
- tt21, tt22都可以为null
- 仅在tt21和tt22都不为null时,需要保证唯一性!
这时的解决方法:Function based index 。
create table ttt2 (tt2_id number, tt21 varchar2(10), tt22 varchar2(10));create or replace function conditional_uniqueness(p_tt21 varchar2, p_tt22 varchar2) return varchar2DETERMINISTICasbegin if(p_tt21 is not null and p_tt22 is not null) then return p_tt21||p_tt22; else return null; end if;end;create unique index ttt2_idx on ttt2(conditional_uniqueness(tt21, tt22));--Fail!insert into ttt2 values(1, '1','1');insert into ttt2 values(1, '1','1');--Successfulinsert into ttt2 values(1, '1',null);insert into ttt2 values(1, '1',null);--Successfulinsert into ttt2 values(1, null,'1');insert into ttt2 values(1, null,'1');commit;
0 0
- Oracle Index 和null 研究
- Oracle/DB2 null key index
- [Index]Null值和索引
- oracle中的''和null
- 【Oracle index】B*Tree索引之NULL统计技巧
- oracle is null 和is not null
- oracle的NULL和0
- oracle null和空字符串
- Oracle 空字符串和NULL
- oracle null 和 空串 ''
- Oracle NULL 和 NOT IN
- oracle null和 ''的区别
- oracle 空字符'' 和Null
- oracle 中 不等于 和 null
- oracle null 和空字符串
- null value index
- Oracle index unusable和invisible的区别
- oracle index
- 串口控件编程
- Eclipse汉化后怎么改回英文版(可切换中英文)
- 九度1084解题报告
- PON无源光纤网络中ONU的VLAN功能
- C++中函数占位符在函数重载中的作用
- Oracle Index 和null 研究
- 九度1054
- 平面中判断点是否在某一三角形内算法 .
- Fiddler过滤指定域名的方法
- Session设置失效的几种方法
- eclipse 在 maven 中常用的几个命令
- java基础学习之-- -异常机制(偶滴神啊,越来越有压力,有点跟不上步伐)
- IBatis——初步总结
- Mysql中使用中间表提高统计查询速度