gpt4 book ai didi

sql - Oracle:基于函数的索引选择性唯一性

转载 作者:行者123 更新时间:2023-12-03 22:11:36 26 4
gpt4 key购买 nike

我必须维护历史,所以我使用 is_deleted 列,它可以有“Y”或“N”。但是对于 is_deleted 'N' 的任何实例,我应该有 (a,b,c) 复合列的 uniwue 条目。

当我尝试创建基于函数的唯一索引时,出现错误。

CREATE UNIQUE INDEX fn_unique_idx ON table1  (CASE WHEN is_deleted='N' then (id, name, type) end);

第 1 行的错误:
ORA-00907: 缺少右括号

请帮忙。

谢谢

最佳答案

你需要类似的东西

CREATE UNIQUE INDEX fn_unique_idx 
ON table1 (CASE WHEN is_deleted='N' THEN id ELSE null END,
CASE WHEN is_deleted='N' THEN name ELSE null END,
CASE WHEN is_deleted='N' THEN type ELSE null END);

约束条件的一个例子
SQL> create table table1 (
2 id number,
3 name varchar2(10),
4 type varchar2(10),
5 is_deleted varchar2(1)
6 );

Table created.

SQL> CREATE UNIQUE INDEX fn_unique_idx
2 ON table1 (CASE WHEN is_deleted='N' THEN id ELSE null END,
3 CASE WHEN is_deleted='N' THEN name ELSE null END,
4 CASE WHEN is_deleted='N' THEN type ELSE null END);

Index created.

SQL> insert into table1 values( 1, 'Foo', 'Bar', 'N' );

1 row created.

SQL> insert into table1 values( 1, 'Foo', 'Bar', 'Y' );

1 row created.

SQL> insert into table1 values( 1, 'Foo', 'Bar', 'Y' );

1 row created.

SQL> insert into table1 values( 1, 'Foo', 'Bar', 'N' );
insert into table1 values( 1, 'Foo', 'Bar', 'N' )
*
ERROR at line 1:
ORA-00001: unique constraint (SCOTT.FN_UNIQUE_IDX) violated


SQL> insert into table1 values( 1, 'Foo', 'Zee', 'N' );

1 row created.

关于sql - Oracle:基于函数的索引选择性唯一性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6702367/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com