最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

OracleIndex和null研究

来源:动视网 责编:小采 时间:2020-11-09 10:28:18
文档

OracleIndex和null研究

OracleIndex和null研究:Oracle Index 和null 研究,这里1可以是任意数字或字母。而这时,select语句的谓词不需要更改,还是t_name is null. Indexing null values 安装关系数据库理论, null表示未知,Oracle b-tree index是不包含null的。考虑如下表: cr
推荐度:
导读OracleIndex和null研究:Oracle Index 和null 研究,这里1可以是任意数字或字母。而这时,select语句的谓词不需要更改,还是t_name is null. Indexing null values 安装关系数据库理论, null表示未知,Oracle b-tree index是不包含null的。考虑如下表: cr


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;

    文档

    OracleIndex和null研究

    OracleIndex和null研究:Oracle Index 和null 研究,这里1可以是任意数字或字母。而这时,select语句的谓词不需要更改,还是t_name is null. Indexing null values 安装关系数据库理论, null表示未知,Oracle b-tree index是不包含null的。考虑如下表: cr
    推荐度:
    标签: oracle 研究 index
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top