外來鍵技術

kitesky發表於2005-02-27

一、語法

FOREIGN KEY 約束主要目的是控制儲存在外來鍵表中的資料,但它還可以控制對主鍵表中資料的修改。FOREIGN KEY 約束並不僅僅只可以與另一表的 PRIMARY KEY 約束相連結,它還可以定義為引用另一表的 UNIQUE 約束。FOREIGN KEY 約束不允許空值,但是,如果任何組合 FOREIGN KEY 約束的列包含空值,則將跳過 FOREIGN KEY 約束的校驗。FOREIGN KEY 可以引用同一表中的其它列(自引用)。一個表最多可包含 253 個 FOREIGN KEY 約束。每個表在其 FOREIGN KEY 約束中最多可以引用 253 個不同的表。
列級 FOREIGN KEY 約束放在列說明部分,表級 FOREIGN KEY 約束放在全部列說明之後,用","和列說明分開。

  • 列級 FOREIGN KEY 約束的 REFERENCES 子句僅能列出一個引用列,且該列必須與定義約束的列具有相同的資料型別。
  • 表級 FOREIGN KEY 約束的 REFERENCES 子句中引用列的數目必須與約束列列表中的列數相同。每個引用列的資料型別也必須與列表中相應列的資料型別相同。

    1) 新建
    作為表定義的一部分在建立表時建立。一個表可以有多個 FOREIGN KEY 約束。
    < column_constraint > ::= [ CONSTRAINT constraint_name ]
        { [ NULL | NOT NULL ]
            | [ { PRIMARY KEY | UNIQUE }
                [ CLUSTERED | NONCLUSTERED ]
                [ WITH FILLFACTOR = fillfactor ]
                [ON {filegroup | DEFAULT} ] ]
            ]
            | [ [ FOREIGN KEY ]
                REFERENCES ref_table [ ( ref_column ) ]
                [ ON DELETE { CASCADE | NO ACTION } ]
                [ ON UPDATE { CASCADE | NO ACTION } ]
                [ NOT FOR REPLICATION ]
            ]
            | CHECK [ NOT FOR REPLICATION ]
            ( logical_expression )
        }

    < table_constraint > ::= [ CONSTRAINT constraint_name ]
        { [ { PRIMARY KEY | UNIQUE }
            [ CLUSTERED | NONCLUSTERED ]
            { ( column [ ASC | DESC ] [ ,...n ] ) }
            [ WITH FILLFACTOR = fillfactor ]
            [ ON { filegroup | DEFAULT } ]
        ]
        | FOREIGN KEY
            [ ( column [ ,...n ] ) ]
            REFERENCES ref_table [ ( ref_column [ ,...n ] ) ]
            [ ON DELETE { CASCADE | NO ACTION } ]
            [ ON UPDATE { CASCADE | NO ACTION } ]
            [ NOT FOR REPLICATION ]
        | CHECK [ NOT FOR REPLICATION ]
            ( search_conditions )
        }

    2) 刪除
    ALTER TABLE table_name DROP CONSTRAINT constraint_name

    3)修改
    必須首先刪除已有的 FOREIGN KEY 約束,然後再透過新定義重新建立。
    ALTER TABLE table_name DROP CONSTRAINT constraint_name
    ALTER TABLE table_name ADD CONSTRAINT constraint_name FOREIGN KEY (外來鍵表的列) REFERENCES 主鍵表(主鍵表的列)

    4) 主鍵表
    顯示關係中主表的名稱,後面是構成主鍵的列。

    5) 外來鍵表
    顯示關係中外來鍵表的名稱,後面是構成外來鍵的列。

  • 二、說明

    1) 建立中檢查現存資料
    在外來鍵表上新增關係時,對資料庫中已存在的資料應用約束。

    2) 對 INSERT 和 UPDATE 強制關係
    對在外來鍵表中插入、刪除或更新的資料應用該約束。如果外來鍵表中存在匹配的行,還將禁止刪除主表中的行。

    3) 對複製強制關係
    在將外來鍵表複製到其它資料庫時應用該約束。NOT FOR REPLICATION

    4) 級聯更新相關的欄位
    無論何時更新主鍵值,都指示 DBMS 自動更新該關係的外來鍵值。ON UPDATE {CASCADE | NO ACTION}
    如果指定 CASCADE,則在父表中更新被引用行時,也將在引用表中更新引用行;
    如果指定 NO ACTION,SQL Server 將產生一個錯誤並回滾父表中的行更新操作。

    5) 級聯刪除相關的欄位
    無論何時刪除主表的被引用行,都指示 DBMS 自動刪除外來鍵表的行。ON DELETE {CASCADE | NO ACTION} 
    如果指定 CASCADE,則從父表中刪除被引用行時,也將從引用表中刪除引用行;
    如果指定 NO ACTION,SQL Server 將產生一個錯誤並回滾父表中的行刪除操作。

    [@more@]

    來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/66009/viewspace-791264/,如需轉載,請註明出處,否則將追究法律責任。

    相關文章