欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > MySQL外鍵約束(FOREIGN KEY)案例講解

MySQL外鍵約束(FOREIGN KEY)案例講解

熱門標簽:400電話可以辦理嗎 外東北地圖標注 云南電商智能外呼系統價格 高清地圖標注道路 大眾點評星級酒店地圖標注 話務外呼系統怎么樣 拉卡拉外呼系統 智能外呼系統復位 臨清電話機器人

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

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

主表刪除某條記錄時,從表中與之對應的記錄也必須有相應的改變。一個表可以有一個或多個外鍵,外鍵可以為空值,若不為空值,則每一個外鍵的值必須等于主表中主鍵的某個值。

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

  • 主表必須已經存在于數據庫中,或者是當前正在創建的表。如果是后一種情況,則主表與從表是同一個表,這樣的表稱為自參照表,這種結構稱為自參照完整性。
  • 必須為主表定義主鍵。
  • 主鍵不能包含空值,但允許在外鍵中出現空值。也就是說,只要外鍵的每個非空值出現在指定的主鍵中,這個外鍵的內容就是正確的。
  • 在主表的表名后面指定列名或列名的組合。這個列或列的組合必須是主表的主鍵或候選鍵。
  • 外鍵中列的數目必須和主表的主鍵中列的數目相同。
  • 外鍵中列的數據類型必須和主表主鍵中對應列的數據類型相同。

在創建表時設置外鍵約束

在 CREATE TABLE 語句中,通過 FOREIGN KEY 關鍵字來指定外鍵,具體的語法格式如下:

[CONSTRAINT 外鍵名>] FOREIGN KEY 字段名 [,字段名2,…]
REFERENCES 主表名> 主鍵列1 [,主鍵列2,…]

例 1

為了展現表與表之間的外鍵關系,本例在 test_db 數據庫中創建一個部門表 tb_dept1,表結構如下表所示。

字段名稱 數據類型 備注
id INT(11) 部門編號
name VARCHAR(22) 部門名稱
location VARCHAR(22) 部門位置

創建 tb_dept1 的 SQL 語句和運行結果如下所示。

mysql> CREATE TABLE tb_dept1
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(22) NOT NULL,
    -> location VARCHAR(50)
    -> );
Query OK, 0 rows affected (0.37 sec)

創建數據表 tb_emp6,并在表 tb_emp6 上創建外鍵約束,讓它的鍵 deptId 作為外鍵關聯到表 tb_dept1 的主鍵 id,SQL 語句和運行結果如下所示。

mysql> CREATE TABLE tb_emp6
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> CONSTRAINT fk_emp_dept1
    -> FOREIGN KEY(deptId) REFERENCES tb_dept1(id)
    -> );
Query OK, 0 rows affected (0.37 sec)

mysql> DESC tb_emp6;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     | int(11)     | NO   | PRI | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  | MUL | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
4 rows in set (1.33 sec)

以上語句執行成功之后,在表 tb_emp6 上添加了名稱為 fk_emp_dept1 的外鍵約束,外鍵名稱為 deptId,其依賴于表 tb_dept1 的主鍵 id。

注意:從表的外鍵關聯的必須是主表的主鍵,且主鍵和外鍵的數據類型必須一致。例如,兩者都是 INT 類型,或者都是 CHAR 類型。如果不滿足這樣的要求,在創建從表時,就會出現“ERROR 1005(HY000): Can't create table”錯誤。

在修改表時添加外鍵約束

外鍵約束也可以在修改表時添加,但是添加外鍵約束的前提是:從表中外鍵列中的數據必須與主表中主鍵列中的數據一致或者是沒有數據。

在修改數據表時添加外鍵約束的語法格式如下:

ALTER TABLE 數據表名> ADD CONSTRAINT 外鍵名>
FOREIGN KEY(列名>) REFERENCES 主表名> (列名>);

例 2

修改數據表 tb_emp2,將字段 deptId 設置為外鍵,與數據表 tb_dept1 的主鍵 id 進行關聯,SQL 語句和運行結果如下所示。

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)

注意:在為已經創建好的數據表添加外鍵約束時,要確保添加外鍵約束的列的值全部來源于主鍵列,并且外鍵列不能為空。

刪除外鍵約束

當一個表中不需要外鍵約束時,就需要從表中將其刪除。外鍵一旦刪除,就會解除主表和從表間的關聯關系。

刪除外鍵約束的語法格式如下所示:

ALTER TABLE 表名> DROP FOREIGN KEY 外鍵約束名>;

例 3

刪除數據表 tb_emp2 中的外鍵約束 fk_tb_dept1,SQL 語句和運行結果如下所示。

mysql> ALTER TABLE tb_emp2
    -> DROP FOREIGN KEY fk_tb_dept1;
Query OK, 0 rows affected (0.19 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`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.00 sec)

可以看到,tb_emp2 中已經不存在 FOREIGN KEY,原有的名稱為 fk_emp_dept 的外鍵約束刪除成功。

到此這篇關于MySQL外鍵約束(FOREIGN KEY)案例講解的文章就介紹到這了,更多相關MySQL外鍵約束(FOREIGN KEY)內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL非空約束(not null)案例講解
  • MySQL 外鍵約束和表關系相關總結
  • MySQL完整性約束的定義與實例教程
  • MySQL 8.0新特性 — 檢查性約束的使用簡介
  • MySQL中外鍵的創建、約束以及刪除
  • Mysql中索引和約束的示例語句
  • MySQL外鍵約束的實例講解
  • 詳解MySQL 外鍵約束
  • mysql完整性約束實例詳解
  • MySQL約束超詳解

標簽:無錫 阿里 溫州 山西 揚州 定西 福州 三明

巨人網絡通訊聲明:本文標題《MySQL外鍵約束(FOREIGN KEY)案例講解》,本文關鍵詞  MySQL,外鍵,約束,FOREIGN,KEY,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL外鍵約束(FOREIGN KEY)案例講解》相關的同類信息!
  • 本頁收集關于MySQL外鍵約束(FOREIGN KEY)案例講解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    丰腴饱满的极品熟妇| 欧美一区二区在线观看| 久久精品一区八戒影视| 人人精品人人爱| 亚洲欧美日韩偷拍| 欧美剧情片在线观看| 一区二区三区在线观看动漫| 99热这里都是精品| 538精品在线观看| 国产精品久久久久aaaa樱花| 国产成人aaa| 国产美女福利视频| 中文字幕中文在线不卡住| 国产成人av在线影院| frxxee中国xxx麻豆hd| 中文字幕av一区 二区| 从欧美一区二区三区| 免费成年人视频在线观看| 国产精品久久久久一区二区三区 | 97超碰免费在线观看| 日本高清不卡aⅴ免费网站| aaaaa级少妇高潮大片免费看| 欧美精品在线一区二区| 午夜精品123| 久久国产精品影院| 久久影院午夜论| 国产一区二区日韩精品| 熟女av一区二区| 亚洲精品videosex极品| 男人的天堂免费| 日韩一区二区电影| 国产尤物一区二区在线| 午夜精品一区二区三级视频| **欧美大码日韩| 69亚洲乱人伦| 精品福利在线导航| 夫妻av一区二区| 欧美综合天天夜夜久久| 午夜在线成人av| 久久精品—区二区三区舞蹈| 国产欧美日韩精品一区| 99久久99久久精品免费观看| 欧美乱妇15p| 黑人巨大精品欧美一区| 免费在线黄色网| 亚洲高清免费视频| 91成人破解版| 日韩一区欧美一区| 精品一区二区视频在线观看| 久久亚洲免费视频| 99精品欧美一区二区三区小说| 777色狠狠一区二区三区| 精品一区免费av| 一本久久综合亚洲鲁鲁五月天| 午夜婷婷国产麻豆精品| 人妻精品久久久久中文| 亚洲美女偷拍久久| 在线 丝袜 欧美 日韩 制服| 欧美国产日本韩| aaa黄色大片| 久久精品无码一区二区三区| 91美女视频网站| 亚洲精品一区在线观看| 不卡视频在线观看| 日韩欧美中文字幕一区| 成人免费视频视频| 日韩欧美亚洲一区二区| 成人午夜伦理影院| 日韩欧美区一区二| 97久久精品人人做人人爽50路| 欧美一级精品在线| a亚洲天堂av| 久久综合色之久久综合| 小日子的在线观看免费第8集| 久久久久久久久久美女| 亚洲综合中文网| 2020国产精品久久精品美国| 人妻换人妻仑乱| 国产调教视频一区| 精品国产av色一区二区深夜久久 | 国产suv精品一区二区68| 亚洲成人精品在线观看| 精品一区二区在线视频| 在线精品视频一区二区| 国产在线一区二区| 欧美一区二区性放荡片| 成人精品一区二区三区四区| 精品少妇一区二区三区在线视频 | 久久久蜜臀国产一区二区| 久草福利在线观看| 亚洲国产成人自拍| 三上悠亚ssⅰn939无码播放 | 三级黄色在线观看| 奇米777欧美一区二区| 欧美亚洲一区二区在线观看| 国产精品18久久久久久久久久久久| 欧美一区二区视频观看视频| 99视频一区二区| 中文字幕av一区二区三区高| 一色道久久88加勒比一| 五月激情综合色| 欧美色手机在线观看| 成人sese在线| 国产日产精品1区| 亚洲久久久久久久| 日韩成人午夜精品| 欧美精品丝袜久久久中文字幕| a级精品国产片在线观看| 国产网红主播福利一区二区| 日韩中文字幕有码| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日韩的一区二区| 99视频超级精品| 《视频一区视频二区| 人人干在线观看| 国产精品亚洲一区二区三区在线| 精品国产一区二区三区久久久蜜月 | 亚洲第一在线综合网站| 91电影在线观看| av成人动漫在线观看| 国产精品久久久久一区二区三区共| 国产福利在线导航| 国产一区二区伦理片| 精品国产凹凸成av人网站| 五月婷婷综合在线观看| 日韩影院免费视频| 欧美一区二区久久| 青青草视频播放| 琪琪久久久久日韩精品| 日韩欧美电影一二三| 人妻精品久久久久中文字幕| 日本欧美一区二区三区乱码| 日韩一区二区免费高清| 人妻无码一区二区三区| 琪琪久久久久日韩精品| www亚洲一区| 亚洲色图27p| 成人精品免费网站| 亚洲日本电影在线| 欧洲另类一二三四区| 9191在线视频| 五月天一区二区| 欧美v国产在线一区二区三区| 加勒比综合在线| 国产在线精品免费av| 欧美国产精品一区二区三区| 激情亚洲综合在线| 久久久久青草大香线综合精品| 国产精品久久免费观看| 国产精品18久久久| 亚洲日本免费电影| 制服丝袜亚洲精品中文字幕| 老司机福利av| 国产成人综合网站| 亚洲蜜臀av乱码久久精品| 欧美日韩一本到| 少妇特黄一区二区三区| 国产一区二区在线视频| 中文字幕日本不卡| 欧美日韩色综合| 丰满少妇一区二区| 国产成人精品网址| 亚洲精品视频观看| 日韩视频一区二区| 黄色精品视频在线观看| 91丨九色丨尤物| 日本不卡中文字幕| 中文字幕成人网| 欧美老人xxxx18| 在线视频第一页| a级精品国产片在线观看| 日韩精品福利网| 国产清纯在线一区二区www| 色久综合一二码| 懂色av粉嫩av蜜乳av| 国产大陆精品国产| 亚洲一区二区3| 久久毛片高清国产| 欧美综合色免费| 老熟妇一区二区| 99久久精品久久久久久清纯| 日韩精品电影在线观看| 国产精品日韩成人| 欧美一区二区三区在线视频| 黄色录像一级片| 亚洲高清无码久久| 国产成人亚洲综合色影视| 亚洲国产va精品久久久不卡综合| 久久这里只有精品6| 欧美最猛性xxxxx直播| 精品欧美一区二区久久久| 99国产麻豆精品| 麻豆国产精品一区二区三区| 亚洲婷婷综合久久一本伊一区 | 日韩电影一区二区三区四区| 中文字幕第一区| 精品精品国产高清a毛片牛牛| 欧美主播一区二区三区| 女人十八毛片嫩草av| 免费啪视频在线观看|