MySQL中的外鍵(Foreign Key)是指一張表中的列或列組合,這些列與另一張表中的一列或多列的值進(jìn)行比較并且添加了引用完整性約束的操作。
外鍵可通過以下步驟實(shí)現(xiàn):
CREATE TABLE 欄目
(
欄目ID INT PRIMARY KEY,
欄目名稱 VARCHAR(20)
);
CREATE TABLE 文章
(
文章ID INT PRIMARY KEY,
文章標(biāo)題 VARCHAR(100),
欄目ID INT,
FOREIGN KEY (欄目ID) REFERENCES 欄目(欄目ID)
);
在第一個(gè)表創(chuàng)建過程中,定義了一個(gè)整數(shù)類型的欄目ID和對(duì)應(yīng)的欄目名稱。在第二個(gè)表的創(chuàng)建過程中,定義了文章ID、文章標(biāo)題和欄目ID。 FOREIGN KEY約束被用于欄目ID列,表示該列引用了欄目表中的欄目ID。這表明當(dāng)在文章表中插入新文章時(shí),必須事先在欄目表中插入具有相同ID的欄目,否則將會(huì)出現(xiàn)錯(cuò)誤。
使用外鍵最大的好處是保證數(shù)據(jù)的完整性。當(dāng)您在一個(gè)表中插入、更新或刪除一行記錄時(shí),外鍵會(huì)強(qiáng)制執(zhí)行相應(yīng)的操作來確保數(shù)據(jù)的一致性。
您還可以使用外鍵來跨表查詢。例如,要查看所有來自特定欄目的文章,可以執(zhí)行以下語句:
SELECT * FROM 文章 WHERE 欄目ID = 1;
此處,所有欄目ID為1的文章將被檢索并顯示。