1. 程式人生 > >定義外來鍵

定義外來鍵

外來鍵是非常重要的概念,也是體現關係資料庫中“關係”二字的體現,通過使用外來鍵,我們才能把互相獨立的表關聯起來,從而表達豐富的業務語義。

外來鍵是定義在源表中的,定義位置同樣為所有欄位定義的後面,使用FOREIGN KEY關鍵字來定義外來鍵欄位,並且使用REFERENCES關鍵字來定義目標表名以及目標表中被關聯的欄位,格式為:


FOREIGN KEY 外來鍵欄位名稱REFERENCES 目標表名(被關聯的欄位名稱)

比如我們建立一張部門資訊表,表中記錄了部門主鍵FId、部門名稱FName、部門級別FLevel等欄位,建表SQL如下:


MYSQL,MSSQLServer:

CREATE TABLE T_Department (FId VARCHAR(20),FName VARCHAR(20), FLevel INT,PRIMARY KEY (FId)) Oracle: CREATE TABLE T_Department (FId VARCHAR2(20),FName VARCHAR2(20), FLevel NUMBER (10) ,PRIMARY KEY (FId)) DB2: CREATE TABLE T_Department (FId VARCHAR(20) NOT NULL,FName VARCHAR(20), FLevel INT,PRIMARY KEY (FId)) 

接著建立員工資訊表,表中記錄工號、姓名以及所屬部門等資訊,為了能夠建立同部門資訊表之間的關聯關係,我們在員工資訊表中儲存部門資訊表中的主鍵,儲存這個主鍵的欄位就被稱為員工資訊表中指向部門資訊表的外來鍵。

建表SQL如下:


MYSQL,MSSQLServer,DB2:

CREATE TABLE T_Employee (FNumber VARCHAR(20),FName VARCHAR(20), FDepartmentId VARCHAR(20), FOREIGN KEY (FDepartmentId) REFERENCES T_Department(FId)) Oracle: CREATE TABLE T_Employee (FNumber VARCHAR2(20),FName VARCHAR2(20), FDepartmentId VARCHAR2(20), FOREIGN KEY (FDepartmentId) REFERENCES T_Department(FId))