我们如何为 MySQL 表的多个字段添加 FOREIGN KEY 约束?


MySQL 允许我们在表中的多个字段上添加 FOREIGN KEY 约束。该条件是子表中的每个外键必须参考不同的父表。

举例

假设我们有一个表 `customer`,它对字段 `cust_unq_id` 有一个主键约束,如下所示 −

mysql> describe customer2;
+-------------+-------------+------+-----+---------+-------+
| Field       | Type        | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| cust_id     | int(11)     | YES  |     | NULL    |       |
| First_name  | varchar(20) | YES  |     | NULL    |       |
| Last_name   | varchar(20) | YES  |     | NULL    |       |
| City        | varchar(10) | YES  |     | NULL    |       |
| cust_unq_id | int(11)     | NO   | PRI | 0       |       |
+-------------+-------------+------+-----+---------+-------+
5 rows in set (0.06 sec)

并且我们有一个表 `orders1`,它已经在字段 `Cust_id` 上有一个外键约束,引用父表 `customer`。

mysql> describe orders1;
+--------------+-------------+------+-----+---------+-------+
| Field        | Type        | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| order_id     | int(11)     | NO   | PRI | NULL    |       |
| Product_name | varchar(25) | YES  |     | NULL    |       |
| orderdate    | date        | YES  |     | NULL    |       |
| Cust_id      | int(11)     | YES  | MUL | NULL    |       |
| cust_unq_id  | int(11)     | YES  |     | NULL    |       |
+--------------+-------------+------+-----+---------+-------+
5 rows in set (0.04 sec)

现在,借助以下 ALTER TABLE 查询,我们可以在字段 `cust_unq_id` 上添加另一个外键约束,引用父表 `customer2`

mysql> Alter table orders1 add FOREIGN KEY(cust_unq_id) REFERENCES Customer2(Cust_unq_id);
Query OK, 0 rows affected (0.25 sec)
Records: 0  Duplicates: 0  Warnings: 0  

mysql> describe orders1;
+--------------+-------------+------+-----+---------+-------+
| Field        | Type        | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| order_id     | int(11)     | NO   | PRI | NULL    |       |
| Product_name | varchar(25) | YES  |     | NULL    |       |
| orderdate    | date        | YES  |     | NULL    |       |
| Cust_id      | int(11)     | YES  | MUL | NULL    |       |
| cust_unq_id  | int(11)     | YES  | MUL | NULL    |       |
+--------------+-------------+------+-----+---------+-------+
5 rows in set (0.06 sec)

从上述结果集中,可以观察到 `orders1` 表有两个外键约束,一个在 `cust_id` 上,另一个在 `cust_unq_id` 上。

更新于:19-6 月-2020

805 浏览量

开启你的职业生涯 之路

通过完成课程获得认证

立即开始
广告
© . All rights reserved.