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

MySQL 外鍵約束和表關(guān)系相關(guān)總結(jié)

 更新時(shí)間:2021年06月18日 11:05:44   作者:程序媛小莊  
一個(gè)項(xiàng)目中如果將所有的數(shù)據(jù)都存放在一張表中是不合理的,比如一個(gè)員工信息,公司只有2個(gè)部門(mén),但是員工有1億人,就意味著員工信息這張表中的部門(mén)字段的值需要重復(fù)存儲(chǔ),極大的浪費(fèi)資源,因此可以定義一個(gè)部門(mén)表和員工信息表進(jìn)行關(guān)聯(lián),而關(guān)聯(lián)的方式就是外鍵。

外鍵(Foreign Key)

按照上述所說(shuō),一張表存儲(chǔ)員工信息會(huì)極大的浪費(fèi)資源,重復(fù)數(shù)據(jù)太多,這個(gè)問(wèn)題就類(lèi)似于將所有的代碼都寫(xiě)在了一個(gè)py文件中,因此我們可以將一個(gè)表拆成不同的表,在這不同的表之間建立關(guān)聯(lián),而建立關(guān)聯(lián)就需要使用外鍵foreign key。外鍵也屬于約束條件的一種。

如何確定表關(guān)系

表與表之間的關(guān)系有三種一對(duì)多、多對(duì)多、一對(duì)一。那么如何確定表與表之間的關(guān)系呢?

在確定表與表之間的關(guān)系時(shí)建議換位思考,什么意思呢?就是分別站在兩張表的角度去考慮,比如員工表和部門(mén)表的關(guān)系:

先站在員工表的角度:?jiǎn)T工表中一個(gè)員工能否屬于多個(gè)部門(mén)呢?答案是不能

再站在部門(mén)表的角度:部門(mén)表中一個(gè)部門(mén)能否有多個(gè)員工呢?答案是可以

因此員工表與部門(mén)表是單向的一對(duì)多,那么員工表和部門(mén)表就是一對(duì)多的關(guān)系。

如何建立表關(guān)系

在建立表關(guān)系時(shí),表與表之間的關(guān)聯(lián)通常以主鍵id作為關(guān)聯(lián)字段。

一對(duì)多關(guān)系 - 員工表和部門(mén)表

在MySQL的關(guān)系在沒(méi)有多對(duì)一的概念,一對(duì)多和多對(duì)一都是一對(duì)多。在創(chuàng)建一對(duì)多表關(guān)系時(shí)需要遵循以下幾點(diǎn):

第一,外鍵字段建立在多的一方,即員工表

第二,在創(chuàng)建表的時(shí)候,一定要先創(chuàng)建被關(guān)聯(lián)一方,即部門(mén)表

第三,在錄入數(shù)據(jù)的時(shí)候也必須先錄入被關(guān)聯(lián)表的數(shù)據(jù),即部門(mén)表的數(shù)據(jù)

第四,當(dāng)不同的表建立關(guān)系時(shí),需要進(jìn)行級(jí)聯(lián)更新和刪除也可以稱(chēng)為同步更新同步刪除,如果不建立級(jí)聯(lián)更新和刪除的話,無(wú)法對(duì)被關(guān)聯(lián)表中被關(guān)聯(lián)的數(shù)據(jù)進(jìn)行刪除或者修改id的操作,因?yàn)閮蓮埍硎窍嗷リP(guān)聯(lián)的。

-- 創(chuàng)建被關(guān)聯(lián)表,部門(mén)表
mysql> create table bm(
    id int primary key auto_increment, 
    bm_name varchar(10), 
    bm_desc char(64)
);
Query OK, 0 rows affected (0.01 sec)

mysql> desc bm;
+---------+-------------+------+-----+---------+----------------+
| Field   | Type        | Null | Key | Default | Extra          |
+---------+-------------+------+-----+---------+----------------+
| id      | int(11)     | NO   | PRI | NULL    | auto_increment |
| bm_name | varchar(10) | YES  |     | NULL    |                |
| bm_desc | char(64)    | YES  |     | NULL    |                |
+---------+-------------+------+-----+---------+----------------+
3 rows in set (0.01 sec)

-- 創(chuàng)建外鍵所在的表,員工表
mysql> create table yg(
    id int primary key auto_increment, 
    yg_name varchar(6), 
    bm_id int, 
    foreign key(bm_id) references bm(id)  -- 表示bm_id是外鍵字段,關(guān)聯(lián)到bm表中的id字段
    on update cascade  # 級(jí)聯(lián)更新
    on delete cascade  # 級(jí)聯(lián)刪除
);
Query OK, 0 rows affected (0.10 sec)

mysql> desc yg;
+---------+------------+------+-----+---------+----------------+
| Field   | Type       | Null | Key | Default | Extra          |
+---------+------------+------+-----+---------+----------------+
| id      | int(11)    | NO   | PRI | NULL    | auto_increment |
| yg_name | varchar(6) | YES  |     | NULL    |                |
| bm_id   | int(11)    | YES  | MUL | NULL    |                |
+---------+------------+------+-----+---------+----------------+
3 rows in set (0.01 sec)


-- 插入數(shù)據(jù)
mysql> insert into bm (bm_name, bm_desc) values ('python', '人生苦短'),('go', 'let us go');
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from bm;
+----+---------+--------------+
| id | bm_name | bm_desc      |
+----+---------+--------------+
|  1 | python  | 人生苦短     |
|  2 | go      | let us go    |
+----+---------+--------------+
2 rows in set (0.00 sec)


mysql> insert into yg (yg_name, bm_id) values ('xu', 1), ('zhuang', 2), ('lili', 1);
Query OK, 3 rows affected (0.09 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from yg;
+----+---------+-------+
| id | yg_name | bm_id |
+----+---------+-------+
|  2 | xu      |     1 |
|  3 | zhuang  |     2 |
|  4 | lili    |     1 |
+----+---------+-------+
3 rows in set (0.00 sec)

-- 外鍵關(guān)聯(lián)的數(shù)據(jù)必須在被關(guān)聯(lián)表中存在否則會(huì)報(bào)錯(cuò)哦~
mysql> insert into yg (yg_name, bm_id) values ('xu', 3);
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`book_manage`.`yg`, CONSTRAINT `yg_ibfk_1` FOREIGN KEY (`bm_id`) REFERENCES `bm` (`id`))

-- 如果不使用級(jí)聯(lián)更新和刪除的話會(huì)出現(xiàn)下面的錯(cuò)誤,下述的SQL語(yǔ)句后面的文章都會(huì)介紹。。。
mysql> update bm set id=5 where id=2;  -- 將bm表中id=2的記錄改為id=5
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`book_manage`.`yg`, CONSTRAINT `yg_ibfk_1` FOREIGN KEY (`bm_id`) REFERENCES `bm` (`id`))

mysql> delete from bm where id =2;  -- 刪除bm表中id為2的那條記錄
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`book_manage`.`yg`, CONSTRAINT `yg_ibfk_1` FOREIGN KEY (`bm_id`) REFERENCES `bm` (`id`)) 

多對(duì)多

多對(duì)多的關(guān)系以書(shū)籍和作者為例進(jìn)行詳細(xì)介紹,為什么書(shū)籍和作者屬于多對(duì)多的關(guān)系呢?

先站在書(shū)籍表的角度:一本書(shū)是否可以有多個(gè)作者?答案是可以

再站在作者表的角度:一個(gè)作者是否可以寫(xiě)多本書(shū)?答案是可以

書(shū)籍表和作者表是雙向的一對(duì)多那么這兩張表的關(guān)系就是多對(duì)多。

我們先來(lái)創(chuàng)建兩張表:

-- 創(chuàng)建書(shū)籍表
create table book(
    id int primary key auto_increment,
    title varchar(32),
    price int,
    author_id int,
    foreign key(author_id) references author(id)
    on update cascade
    on delete cascade
);

-- 創(chuàng)建作者表
create table author(
    id int primary key auto_increment,
    name varchar(32),
    age int,
    book_id int,
    foreign key(book_id) references book(id)
    on update cascade
    on delete cascade
);

如果按照上述方式創(chuàng)建表的話肯定是不可能成功的,在創(chuàng)建一對(duì)多的表關(guān)系時(shí)我我們說(shuō)要先創(chuàng)建被關(guān)聯(lián)表,也就是沒(méi)有外鍵的表,可是多對(duì)多關(guān)系是雙向的一對(duì)多,每張表中都會(huì)有外鍵的存在,怎么辦呢?解決方案就是創(chuàng)建第三張表,這第三張表用來(lái)專(zhuān)門(mén)存儲(chǔ)多對(duì)多關(guān)系的兩張表的關(guān)聯(lián)。

-- 創(chuàng)建書(shū)籍表
mysql> create table book(
    id int primary key auto_increment, 
    name varchar(10), 
    price int
);
Query OK, 0 rows affected (0.01 sec)

-- 創(chuàng)建作者表
mysql> create table author(
    id int primary key auto_increment, 
    name varchar(6), 
    age int
);
Query OK, 0 rows affected (0.01 sec)


-- 創(chuàng)建第三章表,存儲(chǔ)book和author表的關(guān)聯(lián)關(guān)系
mysql> create table book2author(
    id int primary key auto_increment, 
    author_id int, 
    book_id int, 
    foreign key(author_id) references author(id) 
    on update cascade 
    on delete cascade, 	
    foreign key(book_id) references book(id) 
    on update cascade 
    on delete cascade);
Query OK, 0 rows affected (0.02 sec)

一對(duì)一

如果一張表的字段特別多,每次查詢(xún)數(shù)據(jù)時(shí)又不是所有的字段都能用的到,我們就可以將表一一分為二,比如說(shuō)用戶(hù)信息表,用戶(hù)的信息包括用戶(hù)名 密碼 用戶(hù)的年齡 用戶(hù)的性別 地址 電話等等,可能經(jīng)常用的只有用戶(hù)的用戶(hù)名和密碼,這種情況我們就可以將一張用戶(hù)信息表拆分成用戶(hù)基本信息表和用戶(hù)詳細(xì)信息表,同樣判斷這兩張表的關(guān)系還是通過(guò)換位思考:

首先看用戶(hù)基本信息表:一個(gè)用戶(hù)能否有多個(gè)詳細(xì)信息?答案是不可以;

再看用戶(hù)詳情表:一個(gè)用戶(hù)詳情能否屬于多個(gè)用戶(hù)?答案是不可以;

單向的一對(duì)多都不成立,那么兩者之間的表關(guān)系就是一對(duì)一或者沒(méi)有關(guān)系。

使用SQL語(yǔ)句建立一對(duì)一的外鍵關(guān)系時(shí),外鍵建在任意一方都可以,但是推薦將外鍵建在查詢(xún)頻率較高的表中,同樣的,在創(chuàng)建表時(shí)還是先創(chuàng)建被關(guān)聯(lián)表。

-- 創(chuàng)建用戶(hù)詳情表
create table authordetail(
	id int primary key auto_increment,
	phone int,
	addr varchar(64)
);

-- 用戶(hù)基本信息表
create table author(
	id int primary key auto_increment,
    name varchar(32),
    age int,
    authordetali_id int,
    foreign key(authordetali_id) references authordetali(id)
    on update cascade
    on delete cascade
);

表關(guān)系總結(jié)

表關(guān)系建立需要使用外鍵foreign key,判斷表與表之間的關(guān)系通過(guò)換位思考的方式。

一對(duì)多表關(guān)系:外鍵建在多的一方

一對(duì)一表關(guān)系:外鍵建在任意一方都可以,推薦建在查詢(xún)頻率高的一方

多對(duì)多表關(guān)系:需要單獨(dú)創(chuàng)建第三張表存儲(chǔ)兩張表的關(guān)聯(lián)關(guān)系

以上就是MySQL 外鍵約束和表關(guān)系相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 外鍵約束和表關(guān)系的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Navicat連接MySQL錯(cuò)誤描述分析

    Navicat連接MySQL錯(cuò)誤描述分析

    最近遇到了一件非常棘手的問(wèn)題,用Navicat連接MySQL總是出錯(cuò), 網(wǎng)上查閱了一下原因,最終找到解決方案,好吧,下面我就來(lái)回憶一下自己怎么處理這問(wèn)題的,分享到腳本之家平臺(tái)需要的朋友參考下吧
    2021-06-06
  • Mysql配置主從復(fù)制-GTID模式詳解

    Mysql配置主從復(fù)制-GTID模式詳解

    這篇文章主要介紹了Mysql配置主從復(fù)制-GTID模式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • windows mysql 自動(dòng)備份的幾種方法匯總

    windows mysql 自動(dòng)備份的幾種方法匯總

    本篇文章主要對(duì)windows mysql 自動(dòng)備份的幾種方法進(jìn)行整理,具有很好的參考價(jià)值,需要的朋友一起來(lái)看下吧
    2016-12-12
  • MySQL之常用的MySQL優(yōu)化工具解讀

    MySQL之常用的MySQL優(yōu)化工具解讀

    這篇文章主要介紹了MySQL之常用的MySQL優(yōu)化工具,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • MySQL 5.6.51 解壓版(zip版)安裝配置圖文方法

    MySQL 5.6.51 解壓版(zip版)安裝配置圖文方法

    這兩天剛試用了一下MySQL5.6.51,感覺(jué)還不錯(cuò),有兄弟戲稱(chēng)是一個(gè)高富帥版本?,F(xiàn)將MySQL5.6.51 zip解壓版本的安裝配置過(guò)程記錄如下,希望能給需要安裝該版本的朋友一點(diǎn)參考作用
    2015-08-08
  • mysql prompt的用法詳解

    mysql prompt的用法詳解

    本篇文章是對(duì)mysql中prompt的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 淺談MySQL存儲(chǔ)引擎選擇 InnoDB與MyISAM的優(yōu)缺點(diǎn)分析

    淺談MySQL存儲(chǔ)引擎選擇 InnoDB與MyISAM的優(yōu)缺點(diǎn)分析

    MyISAM 是MySQL中默認(rèn)的存儲(chǔ)引擎,一般來(lái)說(shuō)不是有太多人關(guān)心這個(gè)東西。決定使用什么樣的存儲(chǔ)引擎是一個(gè)很tricky的事情,但是還是值我們?nèi)パ芯恳幌?,這里的文章只考慮 MyISAM 和InnoDB這兩個(gè),因?yàn)檫@兩個(gè)是最常見(jiàn)的
    2013-06-06
  • 在MySQL中使用序列的簡(jiǎn)單教程

    在MySQL中使用序列的簡(jiǎn)單教程

    這篇文章主要介紹了在MySQL中使用序列的簡(jiǎn)單教程,是MySQL入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),文中給出了基于PHP和Perl腳本的示例,需要的朋友可以參考下
    2015-05-05
  • MySQL數(shù)據(jù)庫(kù)分庫(kù)分表的方案

    MySQL數(shù)據(jù)庫(kù)分庫(kù)分表的方案

    隨著項(xiàng)目不斷迭代,使用人數(shù)的不斷增加,數(shù)據(jù)庫(kù)中某些表數(shù)據(jù)正在逐步膨脹,往單表千萬(wàn)迅速靠攏,,所以最近也在考慮做一下分庫(kù)分表,本文就給大家詳細(xì)講解了什么分庫(kù)分表和分庫(kù)分表的方案,需要的朋友可以參考下
    2023-11-11
  • Mysql更新varchar存儲(chǔ)Json數(shù)據(jù)的操作方法

    Mysql更新varchar存儲(chǔ)Json數(shù)據(jù)的操作方法

    這篇文章主要介紹了Mysql更新varchar存儲(chǔ)Json數(shù)據(jù)的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12

最新評(píng)論