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; --刪除失敗
在刪除表的時候,如果存在外鍵引用,則必須先刪除從表(也就是把存在相關(guān)外鍵約束的表全部刪掉),才能刪除主表。
以上的外鍵都是物理外鍵,屬于數(shù)據(jù)庫級別的引用,不推薦使用,使用這個會造成數(shù)據(jù)耦合度大大增加。
主鍵:
是唯一標(biāo)識一條記錄,不能有重復(fù)的,不允許為空,用來保證數(shù)據(jù)完整性
外鍵:
是另一表的主鍵, 外鍵可以有重復(fù)的, 可以是空值,用來和其他表建立聯(lián)系用的。所以說,如果談到了外鍵,一定是至少涉及到兩張表。
注意:
1、外鍵字段在創(chuàng)建的時候就應(yīng)該與主表的類型完全一致(長度等等),否則創(chuàng)建外鍵會報錯;
2、外鍵表是不能插入主表不存在的數(shù)據(jù)(該數(shù)據(jù)指的是與主表主鍵或從表外鍵的數(shù)據(jù))。–例如部門號只有1,2,3,4,從表插入數(shù)據(jù)時外鍵值為5就會產(chǎn)生錯誤
——>即外鍵表的外鍵約束不能隨意取值3、當(dāng)修改了主表的數(shù)據(jù)后,關(guān)聯(lián)的外鍵表的外鍵約束已經(jīng)實現(xiàn)了自動修改。
加constraint和不加的區(qū)別
當(dāng)不加constraint,系統(tǒng)將自動給約束起名字,不好記住。 加constraint,可以按照自己的意圖給約束起名字。
補充:MySQL 刪除外鍵操作
1.顯現(xiàn)要刪除的外鍵。 show create table 表名;
2.看到約束;
3.刪除即可。 alter table 表名 drop foreign key 約束名;
總結(jié)
到此這篇關(guān)于Mysql添加外鍵的兩種方式的文章就介紹到這了,更多相關(guān)Mysql添加外鍵內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql中find_in_set函數(shù)的基本使用方法
這篇文章主要給大家介紹了關(guān)于mysql中find_in_set函數(shù)的基本使用方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11mysql多條數(shù)據(jù)合并成一條的3種常見方法
在實際的應(yīng)用開發(fā)中,有時我們需要將多條數(shù)據(jù)合并成一條數(shù)據(jù),以便更好地進行數(shù)據(jù)分析和處理,本文就來介紹一下mysql多條數(shù)據(jù)合并成一條的方法,具有一定的參考價值2023-10-10Windows下通過MySQL Installer安裝MySQL服務(wù)的教程圖解
MYSQL官方提供了Installer方式安裝MYSQL服務(wù)以及其他組件,使的Windows下安裝,卸載,配置MYSQL變得特別簡單。接下來通過圖文并茂的形式給大家介紹Windows下通過MySQL Installer安裝MySQL服務(wù)的教程,一起看看吧2018-10-10mysql 字符串長度計算實現(xiàn)代碼(gb2312+utf8)
PHP對中文字符串的處理一直困擾于剛剛接觸PHP開發(fā)的新手程序員。下面簡要的剖析一下PHP對中文字符串長度的處2011-12-12為mysql數(shù)據(jù)庫添加添加事務(wù)處理的方法
開始首先說明一下,mysql數(shù)據(jù)庫默認的數(shù)據(jù)庫引擎是MyISAM,是不支持事務(wù)的,單數(shù)如果你添加了數(shù)據(jù)執(zhí)行語句是不會出錯的,單數(shù)不管用,即便是回滾事務(wù),記錄也是插入進去了,所有首先我們要做的第一步是更改數(shù)據(jù)庫引擎2011-07-07解決mysql與navicat建立連接出現(xiàn)1251錯誤
在本篇文章里小編給大家整理了一篇關(guān)于mysql與navicat建立連接出現(xiàn)1251錯誤怎么解決的技術(shù)文章,需要的朋友們參考下。2019-08-08