SQL 中的複合外鍵
資料庫設計通常涉及建立表格之間的關係。當一個表的主鍵由多個列組成時,將其連結到另一個表中的外鍵就變得具有挑戰性。本題探討如何在兩個具有複合主鍵和外鍵的表之間建立關係。
問題陳述
考慮以下兩個表:
CREATE TABLE IF NOT EXISTS `tutorial` ( `beggingTime` time NOT NULL, `day` varchar(8) NOT NULL, `tutorId` int(3) NOT NULL, `maxMembers` int(2) NOT NULL, `minMembers` int(1) NOT NULL, PRIMARY KEY (`beggingTime`,`day`,`tutorId`), KEY `tutorId` (`tutorId`) ); CREATE TABLE IF NOT EXISTS `group` ( `groupId` tinyint(3) NOT NULL AUTO_INCREMENT, `status` varchar(20) NOT NULL, `groupName` varchar(50) NOT NULL, PRIMARY KEY (`groupId`) );
目標是在組表中建立一個連結到教學表中的複合主鍵的欄位。問題來了:我們如何有效地關聯這些表?
解決方案
根據 MySQL 文檔,可以設定外鍵對應到複合鍵。這需要在外鍵表中建立多個欄位:
ALTER TABLE `group` ADD COLUMN `beggingTime` time NOT NULL; ALTER TABLE `group` ADD COLUMN `day` varchar(8) NOT NULL; ALTER TABLE `group` ADD COLUMN `tutorId` int(3) NOT NULL; ALTER TABLE `group` ADD FOREIGN KEY (`beggingTime`,`day`,`tutorId`) REFERENCES tutorial(`beggingTime`,`day`,`tutorId`);
此方法在組表中建立與教學表中複合主鍵的元件相對應的附加列。
建議
雖然創建複合外鍵是可能的,但它並不總是最佳的設計選擇。正如其他回應所建議的那樣,建議重新考慮表設計並為教程表使用單列主鍵。這將提高資料庫效能並簡化關係管理。
以上是如何在MySQL中實作複合外鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!