对2列组合的sql唯一约束

时间:2012-04-15 04:07:36

标签: sql database indexing constraints

如何在两列中的两个值的组合上创建唯一约束。

意思

column1  column2 
   2        1 

寻找禁止的约束

column1  column2 
   1        2 

3 个答案:

答案 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

跳过这个帮助。