首頁 >資料庫 >mysql教程 >如何在MySQL中實作複合外鍵?

如何在MySQL中實作複合外鍵?

Susan Sarandon
Susan Sarandon原創
2024-12-23 15:52:10515瀏覽

How to Implement a Composite Foreign Key in MySQL?

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn