如何在两列中的两个值的组合上创建唯一约束。
意思
column1 column2
2 1
寻找禁止的约束
column1 column2
1 2
答案 0 :(得分:5)
如果您的数据库允许索引中的表达式,您可以执行类似这样的操作(ANSI SQL):
CREATE UNIQUE INDEX on your_table (least(column1, column2)
, greatest(column1, column2));
请注意,这是唯一的索引,而不是唯一约束。大多数DBMS的唯一区别是您不能将唯一索引作为外键的目标,但除此之外它们用于相同的目的。
如果您的DBMS没有least()
或greatest()
,您可以使用CASE表达式替换它:
create unique index on your_table
(case column1 < column2 then column1 else column2 end,
case column2 > column1 then column2 else column1 end));
答案 1 :(得分:0)
2列的唯一约束只能防止插入那些确切的2个值(允许切换它们):
所以你需要像这样的触发器(ORACLE):
CREATE TRIGGER trig1
BEFORE INSERT ON TAB
REFERENCING NEW AS NEW
FOR EACH ROW
DECLARE
FOUND NUMBER;
BEGIN
SELECT COUNT(1) into FOUND FROM TAB WHERE
(COLUMN1=:NEW.column2 AND COLUMN2=:NEW.column1)
OR (COLUMN1=:NEW.column1 AND COLUMN2=:NEW.column2);
IF FOUND>0 THEN
raise_application_error (-20001,'INSERT not allowed');
END IF;
END trig1;
警告:未检查语法。
答案 2 :(得分:0)
查看文档,找到了ORACLE SGBD:
CREATE TABLE b(
b1 INT,
b2 INT,
CONSTRAINT bu1 UNIQUE (b1, b2)
USING INDEX (create unique index bi on b(b1, b2)),
CONSTRAINT bu2 UNIQUE (b2, b1) USING INDEX bi);
章节&#34;指定与约束相关的索引&#34;在页面ORACLE documentation。
跳过这个帮助。