MySQL是一款流行的關系型數據庫管理系統,支持設置外鍵約束來保證數據的完整性和一致性。在MySQL中,可以通過CREATE TABLE語句來定義表和外鍵約束。接下來,讓我們來看看如何設置2個外鍵。
CREATE TABLE `orders` (
`order_id` int(11) NOT NULL AUTO_INCREMENT,
`customer_id` int(11) NOT NULL,
`product_id` int(11) NOT NULL,
`quantity` int(11) NOT NULL,
PRIMARY KEY (`order_id`),
FOREIGN KEY (`customer_id`) REFERENCES `customers`(`customer_id`),
FOREIGN KEY (`product_id`) REFERENCES `products`(`product_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
在上面的CREATE TABLE語句中,我們創建了一個名為orders的表,它包含order_id、customer_id、product_id和quantity四個列。其中,order_id列是主鍵列,而customer_id和product_id列則是外鍵列,分別參照了customers和products表的主鍵列customer_id和product_id。通過這兩個外鍵約束,我們保證了在插入和更新orders表的數據時,其關聯的customers和products表中必須存在對應的記錄。
除了在CREATE TABLE語句中設置外鍵約束,還可以使用ALTER TABLE語句來添加外鍵約束。例如:
ALTER TABLE `orders`
ADD CONSTRAINT `fk_customer`
FOREIGN KEY (`customer_id`) REFERENCES `customers`(`customer_id`),
ADD CONSTRAINT `fk_product`
FOREIGN KEY (`product_id`) REFERENCES `products`(`product_id`);
在上面的ALTER TABLE語句中,我們通過ADD CONSTRAINT關鍵字分別添加了名為fk_customer和fk_product的兩個外鍵約束。與CREATE TABLE語句類似,我們指定了外鍵列和參照列,并通過REFERENCES關鍵字指定了參照表和主鍵列。
需要注意的是,在設置外鍵約束時必須先創建被參照表的主鍵,否則會引發錯誤。此外,為了性能和數據一致性的考慮,建議使用InnoDB存儲引擎,因為它支持事務和行級鎖定。