Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Não é possível validar, com opção de novalidate


Você não pode ter valores não exclusivos com um índice exclusivo. Mas você pode ter valores não exclusivos com uma restrição exclusiva que é imposta por um índice não exclusivo. Mesmo que você tenha criado inicialmente um índice não exclusivo, o drop index e enable sintaxe irá tentar recriar um índice único a menos que você forneça mais detalhes no using index seção.

Por exemplo:
SQL> create table my_table(my_column number,
  2     constraint my_constraint unique (my_column));

Table created.

SQL> alter table my_table disable constraint my_constraint drop index;

Table altered.

SQL> insert into my_table select 1 from dual union all select 1 from dual;

2 rows created.

SQL> alter table my_table enable novalidate constraint my_constraint;
alter table my_table enable novalidate constraint my_constraint
*
ERROR at line 1:
ORA-02299: cannot validate (USER.MY_CONSTRAINT) - duplicate keys found


SQL> alter table my_table enable novalidate constraint my_constraint
  2     using index (create index my_index on my_table(my_column));

Table altered.

SQL> --The constraint is enforced, even though other rows violate it.
SQL> insert into my_table values(1);
insert into my_table values(1)
*
ERROR at line 1:
ORA-00001: unique constraint (USER.MY_CONSTRAINT) violated