教你mysql如何增加外來鍵約束

roc_guo發表於2022-01-11

本教程操作環境:windows7系統、mysql8版本、Dell G3電腦。

MySQL 外來鍵約束(FOREIGN KEY)是表的一個特殊欄位,經常與主鍵約束一起使用。對於兩個具有關聯關係的表而言,相關聯欄位中主鍵所在的表就是主表(父表),外來鍵所在的表就是從表(子表)。

外來鍵用來建立主表與從表的關聯關係,為兩個表的資料建立連線,約束兩個表中資料的一致性和完整性。

定義外來鍵時,需要遵守下列規則:

主表必須已經存在於資料庫中,或者是當前正在建立的表。如果是後一種情況,則主表與從表是同一個表,這樣的表稱為自參照表,這種結構稱為自參照完整性。

必須為主表定義主鍵。

主鍵不能包含空值,但允許在外來鍵中出現空值。也就是說,只要外來鍵的每個非空值出現在指定的主鍵中,這個外來鍵的內容就是正確的。

在主表的表名後面指定列名或列名的組合。這個列或列的組合必須是主表的主鍵或候選鍵。

外來鍵中列的數目必須和主表的主鍵中列的數目相同。

外來鍵中列的資料型別必須和主表主鍵中對應列的資料型別相同。

mysql給表增加外來鍵約束

外來鍵約束可以在修改表時新增,但是新增外來鍵約束的前提是:從表中外來鍵列中的資料必須與主表中主鍵列中的資料一致或者是沒有資料。

在修改資料表時新增外來鍵約束的語法格式如下:

ALTER TABLE <資料表名> ADD CONSTRAINT <外來鍵名>
FOREIGN KEY(<列名>) REFERENCES <主表名> (<列名>);
示例

修改資料表 tb_emp2,將欄位 deptId 設定為外來鍵,與資料表 tb_dept1 的主鍵 id 進行關聯

mysql> ALTER TABLE tb_emp2
-> ADD CONSTRAINT fk_tb_dept1
-> FOREIGN KEY(deptId)
-> REFERENCES tb_dept1(id);
Query OK, 0 rows affected (1.38 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> SHOW CREATE TABLE tb_emp2\G
*************************** 1. row ***************************
Table: tb_emp2
Create Table: CREATE TABLE `tb_emp2` (
`id` int(11) NOT NULL,
`name` varchar(30) DEFAULT NULL,
`deptId` int(11) DEFAULT NULL,
`salary` float DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `fk_tb_dept1` (`deptId`),
CONSTRAINT `fk_tb_dept1` FOREIGN KEY (`deptId`) REFERENCES `tb_dept1` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.12 sec)

注意:在為已經建立好的資料表新增外來鍵約束時,要確保新增外來鍵約束的列的值全部來源於主鍵列,並且外來鍵列不能為空。

內容擴充套件:

使用外來鍵約束的時機

老實說,在MySQL中使用InnoDB表的時候,不一定非用外來鍵約束不可,然而,為了外來鍵約束在某些情況下的功用,我們將透過前面提到的例子的程式碼進行具體說明。它包括兩個MyISAM表,分別用於存放部落格文章和評論。

定義資料庫模式時,我們要在這兩個表之間建立起一對多的關係,方法是在存放評論的表中建立一個外來鍵,以將其中的資料行(即評論)對應到特定的部落格文章。下面是建立示例MyISAM表的基本SQL程式碼:

DROP TABLE IF EXISTS `test`.`blogs`;
 
CREATE TABLE `test`.`blogs` (
 
`id` INT(10) UNSIGNED AUTO_INCREMENT,
 
`title` TEXT,
 
`content` TEXT,
 
`author` VARCHAR(45) DEFAULT NULL,
 
PRIROSE KEY (`id`)
 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
 
 
DROP TABLE IF EXISTS `test`.`comments`;
 
CREATE TABLE `test`.`comments` (
 
`id` INT(10) UNSIGNED AUTO_INCREMENT,
 
`blog_id` INT(10) UNSIGNED DEFAULT NULL,
 
`comment` TEXT,
 
`author` VARCHAR(45) DEFAULT NULL,
 
PRIROSE KEY (`id`)
 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

到此這篇關於mysql增加外來鍵約束具體方法的文章就介紹到這了。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69901823/viewspace-2851617/,如需轉載,請註明出處,否則將追究法律責任。

相關文章