深入解析MySQL中的約束
約束是關(guān)系型數(shù)據(jù)庫的一個(gè)重要的功能
主要作用是保證數(shù)據(jù)的完整性,也可以理解為數(shù)據(jù)的正確性(數(shù)據(jù)本身是否正確,關(guān)聯(lián)關(guān)系是否正常)
約束類型
| 類型 | 說明 |
|---|---|
| NOT NULL?空約束 | 指定?空約束的列不能存儲(chǔ) NULL 值 |
| DEFALUT 默認(rèn)約束 | 當(dāng)沒有給列賦值時(shí)使?的默認(rèn)值 |
| UNIQUE 唯?約束 | 指定唯?約束的列每?數(shù)據(jù)必須有唯?的值 |
| PRIMARY KEY 主鍵約束 | NOT NULL 和 UNIQUE的結(jié)合,可以指定?個(gè)列或多個(gè)列,有助于防?數(shù)據(jù) 重復(fù)和提?數(shù)據(jù)的查詢性能 |
| FOREIGN KEY 外鍵約束 | 外鍵約束是?種關(guān)系約束,?于定義兩個(gè)表之間的關(guān)聯(lián)關(guān)系,可以確保數(shù)據(jù)的完整性和?致性 |
| CHECK 約束 | ?于限制列或數(shù)據(jù)在數(shù)據(jù)庫表中的值,確保數(shù)據(jù)的準(zhǔn)確性和可靠性 |
注意:
- UNIQUE 唯?約束 的字段NULL可以重復(fù)插入
- PRIMARY KEY 主鍵約束 的列即使非空也是唯一的
- 如果設(shè)置一個(gè)字段非空且唯一(id bigint not null unique)在desc查詢表結(jié)構(gòu)的時(shí)候會(huì)顯示id的key為PRI

一個(gè)表中不允許有兩個(gè)主鍵,但一個(gè)主鍵可以包含多個(gè)字段(復(fù)合主鍵)

FOREIGN KEY 外鍵約束 表中某個(gè)列的值要建立外鍵關(guān)系,這個(gè)值必須是另一張表的主鍵列,或是唯一約束列并且存在。

語法:foregin key (字段名) reference 主表(列);
create table student( id bigint PRIMARY KEY auto_increment, name varchar(20) not null, age int DEFAULT 18, class_id bigint, foreign key (class_id) references class(id) # 創(chuàng)建外鍵約束 );
當(dāng)子表中存在對(duì)主表的依賴的時(shí)候,不能刪除主表中相應(yīng)的記錄,匯報(bào)一個(gè)主外鍵關(guān)系的錯(cuò)誤。如果要?jiǎng)h除主表中記錄要先刪除子表中記錄。
CHECK 約束可以應(yīng)?于?個(gè)或多個(gè)列,?于限制列中可接受的數(shù)據(jù)值,從?確保數(shù)據(jù)的完整性和準(zhǔn)確性。 在8.0.16開始全??持CHECK約束,之前的版本會(huì)忽略CHECK的定義
# 加?CHECK約束 create table student( id bigint PRIMARY KEY auto_increment, # 設(shè)置?增主鍵 name varchar(20) not null, age int DEFAULT 18, gender char(1), check (age >= 16), check (gender = '男' or gender = '?') );
自增類型

可以讓數(shù)據(jù)庫來維護(hù)主鍵的增長,在插入的時(shí)候先找最大值,然后在這個(gè)基礎(chǔ)上加1,生成一個(gè)新的值,做為一個(gè)新數(shù)據(jù)行的主鍵的值。
在設(shè)置了自增后,也可以指定一個(gè)主鍵值插入,只要不重復(fù)即可。
由于主鍵自增是在最大值的基礎(chǔ)上加1,那么主鍵值在數(shù)據(jù)表中可能是不連續(xù)的。
注意:正常寫入數(shù)據(jù)時(shí),主鍵自增。如果寫入數(shù)據(jù)的時(shí)候,由于某種原因報(bào)錯(cuò)了(主外鍵約束,語法…),也會(huì)生成一個(gè)主鍵值,但記錄不會(huì)成功寫入,這個(gè)主鍵值也會(huì)被視為已使用。下一次寫入數(shù)據(jù)時(shí),就會(huì)發(fā)現(xiàn)主鍵值不連續(xù)的現(xiàn)象
總結(jié)
- NOT NULL 非空約束,被指定 NOT NULL 的列,值不允許為空(必填)
- UNIQUE 唯一約束,這個(gè)列里的值在表中是唯一的,也就是說不能重復(fù)
- PRIMARY KEY 主鍵約束,可以看做是 NOT NULL 和 UNIQUE 的組合,可以用一個(gè) bigint 類型列為表單獨(dú)指定主鍵,同時(shí)也可以指定主鍵自增,用 auto_increment 關(guān)鍵字,自增操作時(shí),會(huì)找到當(dāng)前列中最大的值,然后在這個(gè)基礎(chǔ)上加 1(+1)
- DEFAULT 默認(rèn)約束,如果寫入一行記錄的時(shí)候,指定了默認(rèn)約束的列,如果在寫入數(shù)據(jù)時(shí)沒有指定一個(gè)確定的值就會(huì)用默認(rèn)值進(jìn)行填充該字段的值
- FOREIGN KEY 外鍵約束,一張表要與另一張表的主鍵或唯一鍵進(jìn)行關(guān)聯(lián),說明表與表之間的關(guān)聯(lián)關(guān)系
到此這篇關(guān)于MySQL中的約束詳解的文章就介紹到這了,更多相關(guān)mysql約束內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL實(shí)現(xiàn)批量推送數(shù)據(jù)到Mongo
這篇文章主要為大家詳細(xì)介紹了MySQL如何實(shí)現(xiàn)批量推送數(shù)據(jù)到Mongo,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的可以了解一下2023-05-05
MySQL錯(cuò)誤代碼:1052?Column?'xxx'?in?field?list?is
今天在工作中寫sql語句時(shí)遇到了個(gè)sql錯(cuò)誤,為記錄并不再重復(fù)出錯(cuò),下面這篇文章主要給大家介紹了關(guān)于MySQL錯(cuò)誤代碼:1052?Column?'xxx'?in?field?list?is?ambiguous的原因和解決方法,需要的朋友可以參考下2023-04-04
MySQL中UNION 和 JOIN 多表聯(lián)合查詢方式
本文介紹了在MySQL中UNION和JOIN兩種多表查詢的方式,包括它們的適用場(chǎng)景、語法和特性,JOIN用于關(guān)聯(lián)數(shù)據(jù),而UNION用于合并具有相同結(jié)構(gòu)但無直接關(guān)系的數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧2024-11-11
5個(gè)保護(hù)MySQL數(shù)據(jù)倉庫的小技巧
這篇文章主要為大家詳細(xì)介紹了五個(gè)小技巧,告訴你如何保護(hù)MySQL數(shù)據(jù)倉庫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
MySQL 與 Elasticsearch 數(shù)據(jù)不對(duì)稱問題解決辦法
這篇文章主要介紹了MySQL 與 Elasticsearch 數(shù)據(jù)不對(duì)稱問題解決辦法的相關(guān)資料,對(duì)于 elasticsearch 增量寫入,但經(jīng)常jdbc源一端的數(shù)據(jù)庫可能會(huì)做數(shù)據(jù)庫刪除或者更新操作,這里提供解決辦法,需要的朋友可以參考下2017-08-08
MySQL之MHA高可用配置及故障切換實(shí)現(xiàn)詳細(xì)部署步驟
這篇文章主要介紹了MySQL之MHA高可用配置及故障切換實(shí)現(xiàn)詳細(xì)部署步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
MySQL建表設(shè)置默認(rèn)值/取值范圍的操作代碼
這篇文章主要介紹了MySQL建表設(shè)置默認(rèn)值/取值范圍的操作代碼,文中給大家提到了MySQL創(chuàng)建表時(shí)字符串的默認(rèn)值,本文給大家講解的非常詳細(xì),需要的朋友可以參考下2022-11-11

