视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
OracleIndex和null研究
2020-11-09 10:28:18 责编:小采
文档


Oracle Index 和null 研究,这里1可以是任意数字或字母。而这时,select语句的谓词不需要更改,还是t_name is null.

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);
--Successful
insert into ttt2 values(1, null, null);
insert into ttt2 values(1, null, null);
commit;
--Fail
insert 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 varchar2
    DETERMINISTIC
    as
    begin
    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');
    --Successful
    insert into ttt2 values(1, '1',null);
    insert into ttt2 values(1, '1',null);
    --Successful
    insert into ttt2 values(1, null,'1');
    insert into ttt2 values(1, null,'1');
    commit;

    下载本文
    显示全文
    专题