Mysql添加外鍵的兩種方式詳解
Mysql添加外鍵的幾種方式
注意:添加外鍵是給從表添加(即子表)
父表是主表
方法一:
創(chuàng)建表之前:
FOREIGN KEY (子表id) REFERENCES 關(guān)聯(lián)表名(外主表id)
例如
create table emp( e_id int auto_increment primary key, ename varchar(50) not null, age int, job varchar(20), salary int, entrydate date, managerid int, dept_id int, FOREIGN KEY (dept_id) REFERENCES dept(id) );
方法二:
創(chuàng)建表后添加:
ALTER TABLE 表1 ADD FOREIGN KEY (從表的外鍵) REFERENCES dept(主表的主鍵);
例如: ALTER TABLE emp ADD FOREIGN KEY (dep_id) REFERENCES dept(id);
注意:
主表(dept)存在從表(emp),從表引用了外鍵,不能直接刪除(主表)
DROP TABLE dept; --刪除失敗
在刪除表的時(shí)候,如果存在外鍵引用,則必須先刪除從表(也就是把存在相關(guān)外鍵約束的表全部刪掉),才能刪除主表。
以上的外鍵都是物理外鍵,屬于數(shù)據(jù)庫(kù)級(jí)別的引用,不推薦使用,使用這個(gè)會(huì)造成數(shù)據(jù)耦合度大大增加。
主鍵:
是唯一標(biāo)識(shí)一條記錄,不能有重復(fù)的,不允許為空,用來保證數(shù)據(jù)完整性
外鍵:
是另一表的主鍵, 外鍵可以有重復(fù)的, 可以是空值,用來和其他表建立聯(lián)系用的。所以說,如果談到了外鍵,一定是至少涉及到兩張表。
注意:
1、外鍵字段在創(chuàng)建的時(shí)候就應(yīng)該與主表的類型完全一致(長(zhǎng)度等等),否則創(chuàng)建外鍵會(huì)報(bào)錯(cuò);
2、外鍵表是不能插入主表不存在的數(shù)據(jù)(該數(shù)據(jù)指的是與主表主鍵或從表外鍵的數(shù)據(jù))。–例如部門號(hào)只有1,2,3,4,從表插入數(shù)據(jù)時(shí)外鍵值為5就會(huì)產(chǎn)生錯(cuò)誤
——>即外鍵表的外鍵約束不能隨意取值3、當(dāng)修改了主表的數(shù)據(jù)后,關(guān)聯(lián)的外鍵表的外鍵約束已經(jīng)實(shí)現(xiàn)了自動(dòng)修改。
加constraint和不加的區(qū)別
當(dāng)不加constraint,系統(tǒng)將自動(dòng)給約束起名字,不好記住。 加constraint,可以按照自己的意圖給約束起名字。
補(bǔ)充:MySQL 刪除外鍵操作
1.顯現(xiàn)要?jiǎng)h除的外鍵。 show create table 表名;

2.看到約束;

3.刪除即可。 alter table 表名 drop foreign key 約束名;

總結(jié)
到此這篇關(guān)于Mysql添加外鍵的兩種方式的文章就介紹到這了,更多相關(guān)Mysql添加外鍵內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用MyFlash實(shí)現(xiàn)MySQL數(shù)據(jù)閃回的操作指南
MySQL數(shù)據(jù)閃回是一種高級(jí)功能,它允許你在數(shù)據(jù)庫(kù)中恢復(fù)到某個(gè)特定的時(shí)間點(diǎn),通常是事務(wù)開始或保存點(diǎn)的狀態(tài),以便處理數(shù)據(jù)錯(cuò)誤或回滾意外更改,本文給大家介紹了如何利用MyFlash實(shí)現(xiàn)MySQL數(shù)據(jù)閃回,需要的朋友可以參考下2024-06-06
MySQL的備份工具mysqldump的基礎(chǔ)使用命令總結(jié)
這篇文章主要介紹了MySQL的備份工具mysqldump的基礎(chǔ)使用命令總結(jié),除了基本的導(dǎo)入導(dǎo)出,還介紹了其他一些命令參數(shù)的用法,需要的朋友可以參考下2015-12-12
CentOS7環(huán)境下安裝MySQL5.5數(shù)據(jù)庫(kù)
大家好,本篇文章主要講的是CentOS7環(huán)境下安裝MySQL5.5數(shù)據(jù)庫(kù),感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
CentOS 7.4 64位安裝配置MySQL8.0的詳細(xì)步驟
本文分步驟給大家介紹了CentOS 7.4 64位安裝配置MySQL8.0 的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10
MySQL5.7.18主從復(fù)制搭建(一主一從)教程詳解
MySQL使用3個(gè)線程來執(zhí)行復(fù)制功能(其中1個(gè)在主服務(wù)器上,另兩個(gè)在從服務(wù)器上。這篇文章主要介紹了MySQL5.7.18主從復(fù)制搭建(一主一從)教程詳解,需要的朋友可以參考下2017-08-08
MySQL8.0服務(wù)無(wú)法正常啟動(dòng)的解決過程
這篇文章主要介紹了MySQL8.0服務(wù)無(wú)法正常啟動(dòng)的解決過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12

