在两列组合上添加SQL唯一约束条件

4
如何在两列中的两个值的组合上创建唯一约束条件?
意思是,在两列中某一行数据的两个特定值的组合必须是唯一的。
column1  column2 
   2        1 

寻找不允许的约束条件

column1  column2 
   1        2 

我认为您可能想尝试使用“before insert trigger”来处理这个。 - Chris Farmer
1
所以你想禁止列1小于列2?你能更具体地说明你想要的约束条件吗? - aaaidan
3个回答

7
如果你的数据库允许索引中使用表达式,你可以这样做(ANSI SQL):
CREATE UNIQUE INDEX on your_table (least(column1, column2)
                              , greatest(column1, column2));

请注意,这是一个唯一的索引而不是唯一约束条件。对于大多数数据库管理系统,唯一的区别在于你不能将唯一的索引作为外键的目标,但它们的作用是相同的。
如果你的数据库管理系统没有 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

查看文档,发现这是关于 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);

请查看ORACLE文档页面上的“指定与约束相关联的索引”章节。

希望这能帮到您。


0

仅对两列设置的唯一约束条件可以防止插入这些确切的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;

警告:语法未经检查。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接