首頁(yè)技術(shù)文章正文

MySQL外鍵約束的特點(diǎn)和外鍵約束下的多表操作

更新時(shí)間:2022-08-10 來(lái)源:黑馬程序員 瀏覽量:

什么是外鍵約束?

MySQL 外鍵約束(FOREIGN KEY)是表的一個(gè)特殊字段,經(jīng)常與主鍵約束一起使用。對(duì)于兩個(gè)具有關(guān)聯(lián)關(guān)系的表而言,相關(guān)聯(lián)字段中主鍵所在的表就是主表(父表),外鍵所在的表就是從表(子表)。

外鍵用來(lái)建立主表與從表的關(guān)聯(lián)關(guān)系,為兩個(gè)表的數(shù)據(jù)建立連接,約束兩個(gè)表中數(shù)據(jù)的一致性和完整性。比如,一個(gè)水果攤,只有蘋果、桃子、李子、西瓜等 4 種水果,那么,你來(lái)到水果攤要買水果就只能選擇蘋果、桃子、李子和西瓜,其它的水果都是不能購(gòu)買的。

1660125863814_51.png

外鍵約束的特點(diǎn)

定義一個(gè)外鍵時(shí),需要遵守下列規(guī)則:

主表必須已經(jīng)存在于數(shù)據(jù)庫(kù)中,或者是當(dāng)前正在創(chuàng)建的表。

必須為主表定義主鍵。

主鍵不能包含空值,但允許在外鍵中出現(xiàn)空值。也就是說(shuō),只要外鍵的每個(gè)非空值出現(xiàn)在指定的主鍵中,這 個(gè)外鍵的內(nèi)容就是正確的。

在主表的表名后面指定列名或列名的組合。這個(gè)列或列的組合必須是主表的主鍵或候選鍵。

外鍵中列的數(shù)目必須和主表的主鍵中列的數(shù)目相同。

外鍵中列的數(shù)據(jù)類型必須和主表主鍵中對(duì)應(yīng)列的數(shù)據(jù)類型相同。

創(chuàng)建外鍵約束

方式1-在創(chuàng)建表時(shí)設(shè)置外鍵約束

在 create table 語(yǔ)句中,通過(guò) foreign key 關(guān)鍵字來(lái)指定外鍵,具體的語(yǔ)法格式如下:

[constraint <外鍵名>] foreign key 字段名 [,字段名2,…] references <主表名> 主鍵列1 [,主鍵列2,…]

實(shí)現(xiàn)

create database mydb3; 
use mydb3;
-- 創(chuàng)建部門表
create table if not exists dept(
  deptno varchar(20) primary key ,  -- 部門號(hào)
  name varchar(20) -- 部門名字
);

1660121120838_44.png

方式2-在創(chuàng)建表時(shí)設(shè)置外鍵約束

外鍵約束也可以在修改表時(shí)添加,但是添加外鍵約束的前提是:從表中外鍵列中的數(shù)據(jù)必須與主表中主鍵列中的數(shù)據(jù)一致或者是沒(méi)有數(shù)據(jù)。創(chuàng)建表時(shí)設(shè)置外鍵約束的語(yǔ)法格式如下:

alter table <數(shù)據(jù)表名> add constraint <外鍵名> foreign key(<列名>) references 
<主表名> (<列名>);

實(shí)現(xiàn)

-- 創(chuàng)建部門表
create table if not exists dept2(
  deptno varchar(20) primary key ,  -- 部門號(hào)
  name varchar(20) -- 部門名字
);
-- 創(chuàng)建員工表
create table if not exists emp2(
  eid varchar(20) primary key , -- 員工編號(hào)
  ename varchar(20), -- 員工名字
  age int,  -- 員工年齡
  dept_id varchar(20)  -- 員工所屬部門
 
);
-- 創(chuàng)建外鍵約束
alter table emp2 add constraint dept_id_fk foreign key(dept_id) references dept2 (deptno);

1660121551577_45.png

在外鍵約束下的數(shù)據(jù)操作

1、數(shù)據(jù)插入

 --添加主表數(shù)據(jù)
 -- 注意必須先給主表添加數(shù)據(jù)
insert into dept values('1001','研發(fā)部');
insert into dept values('1002','銷售部');
insert into dept values('1003','財(cái)務(wù)部');
insert into dept values('1004','人事部’);

--添加從表數(shù)據(jù)
  -- 注意給從表添加數(shù)據(jù)時(shí),外鍵列的值不能隨便寫,必須依賴主表的主鍵列
insert into emp values('1','喬峰',20, '1001');
insert into emp values('2','段譽(yù)',21, '1001');
insert into emp values('3','虛竹',23, '1001');
insert into emp values('4','阿紫',18, '1002');
insert into emp values('5','掃地僧',35, '1002');
insert into emp values('6','李秋水',33, '1003');
insert into emp values('7','鳩摩智',50, '1003'); 
insert into emp values('8','天山童姥',60, '1005');  -- 不可以

2、刪除數(shù)據(jù)

--刪除數(shù)據(jù)
 /*
   注意:
       1:主表的數(shù)據(jù)被從表依賴時(shí),不能刪除,否則可以刪除
       2: 從表的數(shù)據(jù)可以隨便刪除
 */
delete from dept where deptno = '1001'; -- 不可以刪除
delete from dept where deptno = '1004'; -- 可以刪除
delete from emp where eid = '7'; -- 可以刪除

刪除外鍵約束

當(dāng)一個(gè)表中不需要外鍵約束時(shí),就需要從表中將其刪除。外鍵一旦刪除,就會(huì)解除主表和從表間的關(guān)聯(lián)關(guān)系。

格式如下:

alter table <表名> drop foreign key <外鍵約束名>;

實(shí)現(xiàn):

alter table emp2 drop foreign key dept_id_fk;


分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!