一文理解MySQL數(shù)據(jù)庫的約束與表的設(shè)計(jì)
1.數(shù)據(jù)庫約束
約束是關(guān)系型數(shù)據(jù)庫提供的一種校驗(yàn)數(shù)據(jù)合法性的機(jī)制.
1.1 約束類型
約束類型 | 說明 | 示例 |
null | 使用not null 指定列不為空 | name varchar(20) not null; |
unique | 指定列為唯一的,不重復(fù)的 | name varchar(20) unique; |
default | 指定列為空時(shí)的默認(rèn)值 | name varchar(20) default "無名氏"; |
主鍵約束 | not null 和unique 的結(jié)合 | id int primary key; |
外鍵約束 | 關(guān)聯(lián)其他表的主鍵或唯一鍵 | foreign key (字段名) references 主表(列) |
check約束 | 保證列的值符合指定的條件 | check(sex='男'or sex='女') |
1.2 null 約束
創(chuàng)建表時(shí)指定某列不為空.
語法:
create table 表名(字段1 類型 not null,字段2 類型...);
示例:
1.3 unique 唯一的約束
創(chuàng)建表時(shí)指定某列為唯一的不重復(fù)的.
語法:
create table 表名(字段1 類型 unique,字段2 類型....);
示例:
1.4 default 默認(rèn)值約束
指定列為空時(shí)的默認(rèn)值
語法:
create table 表名(字段1 類型 default 默認(rèn)值,字段2 類型....);
示例:
1.5 primary key 主鍵約束
創(chuàng)建表時(shí)指定列有唯一確定的標(biāo)識(shí)符
語法:
create table 表名(字段1 類型 parmary key,字段2 類型...);
示例:
學(xué)生id 不為null 且不能重復(fù).
1.6 primary key auto_increment 自增主鍵
對(duì)于整數(shù)類型的主鍵, 常搭配自增auto_increment變?yōu)樽栽鲋麈I, 插入字段不給值時(shí), 使用最 大值+1.
語法:
create table 表名(字段1 int primary key auto_increment,字段2 類型...);
示例:
分布式系統(tǒng)中唯一id生成算法
對(duì)于較小的數(shù)據(jù)量, 所有的數(shù)據(jù)都在一臺(tái)MySQL服務(wù)器上存儲(chǔ),此時(shí)自增主鍵可以很好的工作, 但如果涉及的數(shù)據(jù)量較為龐大, 需要將數(shù)據(jù)部署到多臺(tái)MySQL服務(wù)器上, 這時(shí)再插入數(shù)據(jù)就無法保證自增主鍵的唯一性.因此MySQL內(nèi)部采用分布式系統(tǒng)中唯一id生成算法.
實(shí)現(xiàn)公式:
時(shí)間戳+主機(jī)編號(hào)+隨機(jī)因子 結(jié)合這三部分就可以得到一個(gè)全局唯一的id.
1.7 foreign key 外鍵約束
MySQL外鍵是用來在兩個(gè)表之間建立連接,可以是一列或多列,一個(gè)表可以有多個(gè)外鍵.
- 外鍵是本表的一個(gè)字段, 不是本表的主鍵, 但對(duì)于另一個(gè)表的主鍵.
- 定義外鍵之后不允許刪除另一個(gè)表中具有關(guān)聯(lián)關(guān)系的行.
- 主表(父表): 相關(guān)聯(lián)字段中主鍵所在的表就是主表.
- 從表(子表): 相關(guān)聯(lián)字段中外鍵所在的表就是從表.
語法:
添加外鍵約束
(constraint 外鍵名) foreign key (字段名1),(字段名2..) reference 主表名(主鍵列1,主鍵列2..)
修改表時(shí)添加外鍵約束
alter table 表名 add (constraint 外鍵名) foreign key (列名) references 主表名(列名);
刪除外鍵約束
alter table 表名 drop forigen key (外鍵名);
示例:
MySQL表中, 沒有默認(rèn)對(duì)兩張有關(guān)聯(lián)的表提供檢查機(jī)制, 例如:下圖中插入非法班級(jí), 不會(huì)報(bào)錯(cuò). 因此需要引入外鍵約束.
加入外鍵約束之后再插入非法數(shù)據(jù)就會(huì)報(bào)錯(cuò).
非法修改已插入的數(shù)據(jù)也會(huì)報(bào)錯(cuò).
Tips:
- 父表必須已存在數(shù)據(jù)庫中或是當(dāng)前正在創(chuàng)建的表.
- 父表中的主鍵不能出現(xiàn)空值, 但外鍵可以.所以通常用primary key來約束主鍵.
- 外鍵中列是數(shù)目和數(shù)據(jù)類型必須和父表的主鍵一一對(duì)應(yīng).
- 父表限制子表的插入,字表也約束父表的刪除.(互相制約)
父表中元素的刪除:
實(shí)際應(yīng)用中刪除父表中數(shù)據(jù)的方式通常是邏輯刪除. 當(dāng)一個(gè)商品下架之后, 為了讓客戶可以查看到歷史訂單, 所以不能直接刪除商品信息. 通常需要在建表之初預(yù)留商品下架的字段, 商品下架之后, 給商品下架的字段標(biāo)記賦值達(dá)到偽刪除的效果.
2.表的設(shè)計(jì)
基本思路:
- 先明確實(shí)體
- 再明確實(shí)體之間的聯(lián)系
- 根據(jù)上述內(nèi)容, 嵌套到下面的公式中, 就可做出表.
示例:
粗略設(shè)計(jì)一個(gè)學(xué)生教務(wù)管理系統(tǒng).
- 確定實(shí)體為: 學(xué)生, 課程, 學(xué)生賬號(hào), 學(xué)生班級(jí)
- 學(xué)生與課程之間存在關(guān)系, 學(xué)生與賬號(hào)之間存在關(guān)系, 學(xué)生與班級(jí)之間存在關(guān)系.
- 學(xué)生與課程:多對(duì)多, 學(xué)生與賬號(hào):一對(duì)一, 學(xué)生與班級(jí):一對(duì)多.
2.1 一對(duì)一
一個(gè)人只能有一個(gè)身份證號(hào)碼, 一個(gè)身份證號(hào)碼只對(duì)應(yīng)一個(gè)人.
2.2 一對(duì)多
一個(gè)班級(jí)有多個(gè)學(xué)生, 一個(gè)學(xué)生只對(duì)應(yīng)一個(gè)班級(jí).
2.3 多對(duì)多
一個(gè)學(xué)生可以選擇多個(gè)課程, 一個(gè)課程也可以被多個(gè)學(xué)生選擇.
總結(jié)
到此這篇關(guān)于一文理解MySQL數(shù)據(jù)庫的約束與表設(shè)計(jì)的文章就介紹到這了,更多相關(guān)MySQL約束與表設(shè)計(jì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 淺談關(guān)系型數(shù)據(jù)庫中的約束及應(yīng)用場(chǎng)景
- MySQL數(shù)據(jù)庫表中的約束詳解
- MySQL數(shù)據(jù)庫的約束使用實(shí)例
- MySQL數(shù)據(jù)庫約束操作示例講解
- SQL?Server數(shù)據(jù)庫創(chuàng)建表及其約束條件的操作方法
- MySQL數(shù)據(jù)庫的約束限制詳解
- MySQL數(shù)據(jù)庫表約束講解
- MySQL示例講解數(shù)據(jù)庫約束以及表的設(shè)計(jì)
- MySQL數(shù)據(jù)庫如何給表設(shè)置約束詳解
- MySQL?數(shù)據(jù)庫的約束及數(shù)據(jù)表的設(shè)計(jì)原理
- Mysql關(guān)于數(shù)據(jù)庫是否應(yīng)該使用外鍵約束詳解說明
- 深入理解數(shù)據(jù)庫之表的唯一、自增等七大約束
相關(guān)文章
關(guān)于django連接mysql數(shù)據(jù)庫并進(jìn)行數(shù)據(jù)庫的創(chuàng)建的問題
這篇文章主要介紹了django連接mysql數(shù)據(jù)庫并進(jìn)行數(shù)據(jù)庫的創(chuàng)建,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06解決mysql安裝時(shí)出現(xiàn)error Nr.1045問題的方法
這篇文章主要為大家詳細(xì)介紹了解決mysql安裝時(shí)出現(xiàn)error Nr.1045問題的方法,感興趣的小伙伴們可以參考一下2016-06-06關(guān)于mysql delete的問題小結(jié)
關(guān)于mysql delete的問題,需要的朋友可以參考下。2011-05-05mysql如何將數(shù)據(jù)庫中的所有表結(jié)構(gòu)和數(shù)據(jù)導(dǎo)入到另一個(gè)庫
介紹了如何使用mysqldump命令備份和導(dǎo)入數(shù)據(jù)庫,以及創(chuàng)建目標(biāo)數(shù)據(jù)庫的步驟,首先使用mysqldump備份源數(shù)據(jù)庫,然后在目標(biāo)數(shù)據(jù)庫中創(chuàng)建數(shù)據(jù)庫,并將備份文件導(dǎo)入到目標(biāo)數(shù)據(jù)庫,確保數(shù)據(jù)結(jié)構(gòu)和內(nèi)容完整復(fù)制,提到了DataGrip、Navicat在導(dǎo)入導(dǎo)出過程中可能出現(xiàn)的問題2024-10-10MySQL創(chuàng)建和刪除數(shù)據(jù)表的命令及語法詳解
這篇文章主要介紹了MySQL創(chuàng)建和刪除數(shù)據(jù)表的命令及語法,是MySQL入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-11-11關(guān)于MYSQL 你需要知道的數(shù)據(jù)類型和操作數(shù)據(jù)表
這篇文章主要介紹了關(guān)于MYSQL中數(shù)據(jù)類型的知識(shí)和操作數(shù)據(jù)表的方法,文中講解非常詳細(xì)供大家參考學(xué)習(xí),感興趣的朋友可以了解下2020-06-06MySQL連接異常報(bào)10061錯(cuò)誤問題解決
這篇文章主要介紹了MySQL連接異常報(bào)10061錯(cuò)誤問題解決,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08