Oracle: выборочная уникальность индекса на основе функций - PullRequest
8 голосов
/ 15 июля 2011

Мне нужно вести историю, поэтому я использую столбец is_deleted, который может иметь «Y» или «N». Но для любого экземпляра is_deleted 'N' у меня должна быть уникальная запись для (a, b, c) составных столбцов.

Когда я пытаюсь создать уникальный индекс на основе функции, я получаю сообщение об ошибке.

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

ОШИБКА в строке 1: ORA-00907: отсутствует правая скобка

Пожалуйста, помогите.

Спасибо

Ответы [ 2 ]

18 голосов
/ 15 июля 2011

Вам нужно что-то вроде

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.
0 голосов
/ 01 августа 2018
CREATE UNIQUE INDEX fn_unique_idx ON table1  
    (CASE WHEN is_deleted='N' then (id||','|| name||','|| type) end);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...