2010-01-19 24 views
127

Ho un vincolo chiamato users.SYS_C00381400. Come posso trovare che cosa è questo vincolo? C'è un modo per interrogare tutti i vincoli?Oracle trova un vincolo

+0

come sapere vincolo? users.SYS_C00381400 – Vinay

+0

Il nome del vincolo visualizzato in un messaggio di errore. –

risposta

195
select * from all_constraints 
where owner = '<NAME>' 
and constraint_name = 'SYS_C00381400' 
/

Come tutti i dati viste del dizionario, questo un user_constraints vista se si desidera solo per controllare il vostro schema corrente e una vista DBA_CONSTRAINTS per gli utenti di amministrazione.

La costruzione del nome del vincolo indica un nome del vincolo generato dal sistema. Ad esempio, se si specifica NOT NULL in una dichiarazione di tabella. O in effetti una chiave primaria o unica. Ad esempio:

SQL> create table t23 (id number not null primary key) 
    2/

Table created. 

SQL> select constraint_name, constraint_type 
    2 from user_constraints 
    3 where table_name = 'T23' 
    4/

CONSTRAINT_NAME    C 
------------------------------ - 
SYS_C00935190     C 
SYS_C00935191     P 

SQL> 

'C' per il controllo, per 'P' primaria.

Generalmente è una buona idea fornire ai vincoli relazionali un nome esplicito. Ad esempio, se il database crea un indice per la chiave primaria (cosa che farà se tale colonna non è già indicizzata) utilizzerà il nome del vincolo o il nome dell'indice. Non si desidera un database completo di indici denominati come SYS_C00935191.

La maggior parte delle persone non si preoccupa di nominare i vincoli NOT NULL.

19

Per ottenere una descrizione più dettagliata (che i riferimenti tabella/colonna quale tabella/colonna) è possibile eseguire la seguente query:

SELECT uc.constraint_name||CHR(10) 
    ||  '('||ucc1.TABLE_NAME||'.'||ucc1.column_name||')' constraint_source 
    ,  'REFERENCES'||CHR(10) 
    ||  '('||ucc2.TABLE_NAME||'.'||ucc2.column_name||')' references_column 
FROM user_constraints uc , 
    user_cons_columns ucc1 , 
    user_cons_columns ucc2 
WHERE uc.constraint_name = ucc1.constraint_name 
AND uc.r_constraint_name = ucc2.constraint_name 
AND ucc1.POSITION  = ucc2.POSITION -- Correction for multiple column primary keys. 
AND uc.constraint_type = 'R' 
AND uc.constraint_name = 'SYS_C00381400' 
ORDER BY ucc1.TABLE_NAME , 
    uc.constraint_name; 

Da here.

4

forse questo può aiutare ..

SELECT constraint_name, constraint_type, column_name 
from user_constraints natural join user_cons_columns 
where table_name = "my_table_name"; 
Problemi correlati