簡體   English   中英

2 列組合上的 sql 唯一約束

[英]sql unique constraint on a 2 columns combination

如何對兩列中的兩個值的組合創建唯一約束。

意義

column1  column2 
   2        1 

尋找禁止的約束

column1  column2 
   1        2 

如果您的數據庫允許索引中的表達式,您可以執行以下操作(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));

查看文檔,為 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 文檔頁面上的“指定與約束關聯的索引”一章。

跳這個幫助。

對 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;

警告:未檢查語法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM