MySQL 如何在表中添加多个字段的FOREIGN KEY约束?
MySQL允许我们在表中的多个字段上添加FOREIGN KEY约束。唯一的条件是,子表中每个外键必须引用不同的父表。
阅读更多:MySQL 教程
示例
假设我们有一个名为’customer2’的表,它在字段’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’上。