我們在向 MySQL 表中的多個欄位新增 FOREIGN KEY 約束方面可以如何操作?
MySQL 允許我們在表中的多個欄位上新增 FOREIGN KEY 約束。條件是子表中的每個外部索引鍵必須引用不同的父表。
示例
假設我們有一個表 '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’ 上。
廣告