我正在尝试为两列的组合实施唯一约束。我正在运行oracle 11g。
具体地说,我有两列A和B。
我在下面这样一行
A B
1 2
然后我希望以下组合在插入时失败
A B
1 2
2 1
在Oracle中使用唯一索引是否可以实现?
答案 0 :(得分:6)
是的,有可能(例如,使用生成的列):
CREATE TABLE tab(A INT NOT NULL, B INT NOT NULL);
ALTER TABLE tab ADD c1 AS (LEAST(A,B));
ALTER TABLE tab ADD c2 AS (GREATEST(A,B));
CREATE UNIQUE INDEX UQ_tab ON tab(c1,c2);
如果需要,您可以隐藏这些列(Oracle 12c):
ALTER TABLE tab MODIFY c1 INVISIBLE;
ALTER TABLE tab MODIFY c2 INVISIBLE;
更简单的方法:
CREATE UNIQUE INDEX UQ_tab ON tab(least(A,B), greatest(A,B));
答案 1 :(得分:2)
您可以将UNIQUE INDEX
与LEAST
,GREATEST
和COALESCE
函数一起使用:
CREATE TABLE table_name (
a INT,
b INT
);
CREATE UNIQUE INDEX table_name__a__b__u ON TABLE_NAME(
COALESCE( LEAST( a, b ), a, b ),
GREATEST( a, b )
);
如果其中一个值为COALESCE
,则需要包含NULL
。
INSERT INTO table_name ( a, b ) VALUES ( 1, 2 );
1 rows affected
INSERT INTO table_name ( a, b ) VALUES ( 3, NULL );
1 rows affected
INSERT INTO table_name ( a, b ) VALUES ( 2, 1 );
ORA-00001: unique constraint (SCHEMA_NAME.TABLE_NAME__A__B__U) violated
INSERT INTO table_name ( a, b ) VALUES ( NULL, 3 );
ORA-00001: unique constraint (SCHEMA_NAME.TABLE_NAME__A__B__U) violated