MySQL是一種廣泛使用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)。MySQL提供了外鍵(foreign key)約束,允許您在表之間建立關(guān)系,以確保數(shù)據(jù)的完整性。在MySQL中,外鍵約束可以幫助您確保父表和子表之間的數(shù)據(jù)一致性。
CREATE TABLE author ( author_id INT(11) AUTO_INCREMENT PRIMARY KEY, author_name VARCHAR(255), author_email VARCHAR(255) ); CREATE TABLE book ( book_id INT(11) AUTO_INCREMENT PRIMARY KEY, book_title VARCHAR(255), book_author_id INT(11), CONSTRAINT fk_author_id FOREIGN KEY (book_author_id) REFERENCES author(author_id) );
在此示例中,我們創(chuàng)建了兩個表:作者(author)和書籍(book)。我們?yōu)樽髡弑韯?chuàng)建了一個主鍵(author_id),并在書籍表中創(chuàng)建了一個外鍵(book_author_id)來引用作者表的主鍵。外鍵約束使用CONSTRAINT關(guān)鍵字來指定,fk_author_id是外鍵的名稱。外鍵是通過FOREIGN KEY關(guān)鍵字指定的。語法:FOREIGN KEY (child_column) REFERENCES parent_table(parent_column)。這將確保任何在書籍表(子表)中插入的作者ID值都存在于作者表(父表)的作者ID列中。
請注意,外鍵不是自動生成的,您必須明確指定它們。如果在定義外鍵時使用了ON DELETE CASCADE選項,將可以在父表(author)中刪除記錄時自動刪除子表(book)中的相關(guān)條目。此選項還可以在父表更新時更新子表中的外鍵。
需要注意的是,有些MySQL存儲引擎不支持外鍵約束,例如MyISAM。如果您想在此類引擎上使用外鍵,您必須手動篩選和保證數(shù)據(jù)和完整性。