欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql添加外鍵的兩種方式詳解

 更新時間:2023年04月10日 15:46:59   作者:durseme_.  
外鍵可以保持數(shù)據(jù)一致性,完整性,主要目的是控制存儲在外鍵表中的數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于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ù)的基本使用方法

    mysql中find_in_set函數(shù)的基本使用方法

    這篇文章主要給大家介紹了關(guān)于mysql中find_in_set函數(shù)的基本使用方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • mysql多條數(shù)據(jù)合并成一條的3種常見方法

    mysql多條數(shù)據(jù)合并成一條的3種常見方法

    在實際的應(yīng)用開發(fā)中,有時我們需要將多條數(shù)據(jù)合并成一條數(shù)據(jù),以便更好地進行數(shù)據(jù)分析和處理,本文就來介紹一下mysql多條數(shù)據(jù)合并成一條的方法,具有一定的參考價值
    2023-10-10
  • win7下mysql5.7.17安裝配置方法圖文教程

    win7下mysql5.7.17安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了win7下mysql5.7.17安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • MySql索引和索引創(chuàng)建策略

    MySql索引和索引創(chuàng)建策略

    這篇文章主要介紹了MySql索引和索引創(chuàng)建策略,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下,希望對你的學(xué)習(xí)又是幫助
    2022-08-08
  • MySQL服務(wù)器線程數(shù)的查看方法詳解

    MySQL服務(wù)器線程數(shù)的查看方法詳解

    這篇文章主要介紹了MySQL服務(wù)器線程數(shù)的查看方法,結(jié)合實例形式分析了mysql線程數(shù)查看的相關(guān)命令、配置、參數(shù)及相關(guān)使用技巧,需要的朋友可以參考下
    2018-03-03
  • Windows下通過MySQL Installer安裝MySQL服務(wù)的教程圖解

    Windows下通過MySQL Installer安裝MySQL服務(wù)的教程圖解

    MYSQL官方提供了Installer方式安裝MYSQL服務(wù)以及其他組件,使的Windows下安裝,卸載,配置MYSQL變得特別簡單。接下來通過圖文并茂的形式給大家介紹Windows下通過MySQL Installer安裝MySQL服務(wù)的教程,一起看看吧
    2018-10-10
  • mysql 字符串長度計算實現(xiàn)代碼(gb2312+utf8)

    mysql 字符串長度計算實現(xiàn)代碼(gb2312+utf8)

    PHP對中文字符串的處理一直困擾于剛剛接觸PHP開發(fā)的新手程序員。下面簡要的剖析一下PHP對中文字符串長度的處
    2011-12-12
  • MySQL中ADDDATE()函數(shù)的使用教程

    MySQL中ADDDATE()函數(shù)的使用教程

    這篇文章主要介紹了MySQL中ADDDATE()函數(shù)的使用教程,是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-05-05
  • 為mysql數(shù)據(jù)庫添加添加事務(wù)處理的方法

    為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錯誤

    解決mysql與navicat建立連接出現(xiàn)1251錯誤

    在本篇文章里小編給大家整理了一篇關(guān)于mysql與navicat建立連接出現(xiàn)1251錯誤怎么解決的技術(shù)文章,需要的朋友們參考下。
    2019-08-08

最新評論