" />

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

MySQL數(shù)據(jù)庫約束操作示例講解

 更新時(shí)間:2022年11月15日 17:07:54   作者:熬夜磕代碼丶  
約束是用來限制表中的數(shù)據(jù)長什么樣子的,即什么樣的數(shù)據(jù)可以插入到表中,什么樣的數(shù)據(jù)插入不到表中,下面這篇文章主要給大家介紹了關(guān)于如何通過一文理解MySQL數(shù)據(jù)庫的約束與表的設(shè)計(jì)的相關(guān)資料,需要的朋友可以參考下

一、約束是什么

約束就是,在創(chuàng)建表的時(shí)候,對表設(shè)置一些規(guī)則,只有滿足這些規(guī)則,才可以插入數(shù)據(jù),我們把這些規(guī)則叫做約束

常見的約束有:

約束類型規(guī)則
Not Null指定某列不能存儲NULL值
UNIQUE保證某列的每行必須有唯一的值
DEFAULT給沒有賦值的列賦默認(rèn)值
PRIMARY KEYNot NULL 與 UNIQUE的結(jié)合,一個表的特定記錄
FOREIGN KEY保證一個表匹配另一個表的值,遵守參照完整性
CHECK保證列符合指定條件

數(shù)據(jù)庫約束是數(shù)據(jù)庫的一個重要功能,數(shù)據(jù)的 “完整性”(正確的數(shù)據(jù))可以通過人工的方式進(jìn)行確定,但人工還是有一點(diǎn)的缺陷,約束,就是讓數(shù)據(jù)庫幫助我們更好的檢查數(shù)據(jù)是否正確

二、約束的具體操作

Not NULL

 create table stu(
 id int,
 name varchar(50),
 sex char(3)
 );

當(dāng)我們建一個表時(shí),是允許為NULL的,如果我們不允許這一列為空時(shí),我們就需要加上Not NULL約束。

 create table stu(
 id int not null,
 name varchar(50),
 sex char(3)
 );

當(dāng)我們加上約束時(shí),可以發(fā)現(xiàn)id這一列不允許為空,我們試著插入一個為NULL的id試一下。

當(dāng)我們插入的id為空時(shí),系統(tǒng)會報(bào)id 這一列不能為空的錯誤。

當(dāng)我們插入一個非NULL的數(shù)據(jù)時(shí),可以成功插入。

UNIQUE

在我們某些業(yè)務(wù)需要中某些列的數(shù)據(jù)不能夠重復(fù),比如: 我們每個人的身份證號,大學(xué)生的學(xué)號,這些數(shù)據(jù)是唯一標(biāo)識性的不能夠重復(fù)。

 create table stu(
 id int unique,
 name varchar(50),
 sex char(3)
 );

這里的UNI == unique.

我們試著插入一下數(shù)據(jù)看看。

我們可以發(fā)現(xiàn)再插入不同的id數(shù)據(jù)時(shí)是可以正常插入的,當(dāng)我們再次插入已經(jīng)出現(xiàn)過的id時(shí),系統(tǒng)會報(bào)一個重復(fù)條目的錯誤。

一個小小的思考,數(shù)據(jù)庫是如何判斷你當(dāng)前這一條記錄是否為重復(fù)的?

當(dāng)然是先去查找,然后再去插入。

有的同學(xué)肯定會說,加上約束之后,數(shù)據(jù)庫的執(zhí)行速度不就大大的下降了,這里的查找是(借助索引進(jìn)行查找的,效率相對比較高,后面我們會介紹索引的相關(guān)知識),執(zhí)行效率確實(shí)受到了一定的影響,但比起手工去檢查,代價(jià)小的很多。

約束的組合使用

約束不僅可以單獨(dú)使用,而且可以多個組合起來對某一列進(jìn)行約束。

比如同時(shí)加上: Not NULL 和 unique(這里注意的是多個約束之間用空格間隔開,而不是逗號).

我們可以發(fā)現(xiàn)約束之間用逗號間隔會報(bào)錯。

我們可以發(fā)現(xiàn)當(dāng)我們同時(shí)使用 Not NULL 和 unique約束時(shí),出現(xiàn)了一個PRI,PRI == primary key,這是什么我們往下看。

PRIMARY KEY

主鍵約束就是: not null + unique.

我們試著插入幾組數(shù)據(jù)。

我們可以發(fā)現(xiàn)主鍵列不能插入NULL類型的數(shù)據(jù)。

我們可以發(fā)現(xiàn)主鍵列插入不同的數(shù)據(jù)是OK的,如果插入相同的數(shù)據(jù),就會報(bào)錯。

主鍵也同樣是在插入記錄的時(shí)候,先查詢,在插入:

正因?yàn)橹麈I和unique都有先查詢的過程,mysql就會默認(rèn)給這些列添加索引,提高查詢速度。

我們可以簡單來驗(yàn)證一下,我們可以發(fā)現(xiàn)id列確實(shí)存在索引。

主鍵的注意事項(xiàng):

1.在開發(fā)過程中,大部分的表都會存在一個主鍵,逐漸往往是一個整數(shù)類型的id.

2.在mysql中,一個表里,只能存在一個主鍵,不能多個。

3.mysql允許將多個列共同作為一個主鍵(聯(lián)合主鍵)

4.mysql有自帶的"自增主鍵"(主鍵需要保證不重復(fù),如果我們手動生成的話比較困難,這時(shí)我們就可以讓mysql自動幫我們生成。

-- 設(shè)置自增主鍵
create table stu(id int primary key auto_increment);

當(dāng)我們將某一列設(shè)置為自增主鍵時(shí),如果需要系統(tǒng)自動生成的話,我們插入null即可, 這里的null不是說把這個值設(shè)置為Null,而是交給數(shù)據(jù)庫使用自增主鍵。

每一個插入數(shù)據(jù)時(shí),mysql都會找到上一條記錄,自增。

我們也可以插入指定值。

我們可以發(fā)現(xiàn),當(dāng)我們指定值插入后,在使用自增主鍵,并不會去利用中間空余的間隙,而是參照最大值進(jìn)行自增。(這里其實(shí)是我們很常見的一個用空間換取時(shí)間的行為).

如果mysql的數(shù)據(jù)量非常大時(shí),自增主鍵還可以使用嗎?如果可以使用,又是如何分配呢?

當(dāng)我們數(shù)據(jù)量較小時(shí),所有的數(shù)據(jù)都在mysql服務(wù)器當(dāng)中存儲。

但是如果mysql的數(shù)據(jù)量很大時(shí),一臺主機(jī)可能放不下,就需要進(jìn)行分庫分表的操作。

當(dāng)數(shù)據(jù)過多時(shí),就需要分庫分表,實(shí)際上就是把一個大的表分為多個小的表,每個服務(wù)器存取一部分?jǐn)?shù)據(jù)。

這里我們就分為三個服務(wù)器進(jìn)行存儲,每個服務(wù)器的表占各自的比例,三個服務(wù)器中的主鍵值是不能重復(fù)的。

三個服務(wù)器中的表的自增主鍵id是如何分配?

這里涉及到"分布式系統(tǒng)唯一id生成算法"

大概公式是: 時(shí)間戳 + 主機(jī)編號 + 隨機(jī)因子 > 這三部分得到一個全局唯一的id

DEFAULT

在某些情況下,有些列的值大多數(shù)都是重復(fù)的,比如一個班的30個人,28個是男生,只有兩個女生,那么我們就可以把性別列默認(rèn)值設(shè)置為"男".

create table stu(id int primary key,name varchar(50),sex char(3) default '男');

我們可以看到性別這一列默認(rèn)為男。

我們可以發(fā)現(xiàn)當(dāng)我們沒有插入sex這一列,自動為默認(rèn)值’男’.

FOREIGN KEY

外鍵約束是建立在兩張表之間的約束。

比如每個班的同學(xué)的班級號都是一樣的,我們就可以用班級號來建立班級表和學(xué)生表之間的約束.

create table class(classId int primary key,name varchar(50));

我們先創(chuàng)建一個班級表,插入一組數(shù)據(jù)。

create table stu(id int primary key,name varchar(50),classId int,foreign key(classId) references class(classId));

這個是外鍵約束的語法。

外鍵約束的含義時(shí),stu表中的classId必須在class表中是存在的。

當(dāng)我們插入class存在的classid為001的數(shù)據(jù)可以成功插入。

當(dāng)我們插入的classId在class中不存在時(shí),就會插入失敗。

此處起到約束的class表是"父表(parent)",被約束的表叫做"子表(child).

實(shí)則不然,我們子表對父表也產(chǎn)生了一定的約束。

我們可以發(fā)現(xiàn),無法刪除外鍵約束的父表。

這也很好理解,如果父表刪除了,子表的數(shù)據(jù)去哪里參考,如果想刪除,可以先刪除子表,在刪除父表。

我們可以發(fā)現(xiàn)當(dāng)父表相應(yīng)列不是主鍵時(shí),無法建立外鍵約束,這是為什么呢?

因?yàn)槊看卧俳o子表插入時(shí),都會先在父表先查詢這個id是否存在,如果表的數(shù)據(jù)十分大時(shí),效率十分地低,要使用索引。

要想創(chuàng)建外鍵,就要求父類相應(yīng)的列,有primary 或者 unique約束

到此這篇關(guān)于MySQL數(shù)據(jù)庫約束操作示例講解的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù)庫約束內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql8.0.23 msi安裝超詳細(xì)教程

    mysql8.0.23 msi安裝超詳細(xì)教程

    這篇文章主要介紹了mysql8.0.23 msi安裝超詳細(xì)教程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • MySQL編程中的6個實(shí)用技巧

    MySQL編程中的6個實(shí)用技巧

    這篇文章主要介紹了MySQL編程中的6個實(shí)用技巧,本文講解了每一行命令都是用分號(;)作為結(jié)束、采用關(guān)聯(lián)數(shù)組存取查詢結(jié)果、TEXT、DATE、和SET數(shù)據(jù)類型等內(nèi)容,需要的朋友可以參考下
    2015-02-02
  • SQL實(shí)現(xiàn)Excel的10個常用功能的示例詳解

    SQL實(shí)現(xiàn)Excel的10個常用功能的示例詳解

    SQL,數(shù)據(jù)分析崗的必備技能,你可以不懂Python,R,不懂可視化,不懂機(jī)器學(xué)習(xí)。但SQL,你必須懂。本文為大家總結(jié)了SQL實(shí)現(xiàn)Excel的10個常用功能的示例代碼,感興趣的可以了解一下
    2022-07-07
  • Mysql跨表更新 多表update sql語句總結(jié)

    Mysql跨表更新 多表update sql語句總結(jié)

    Mysql跨表更新一直是大家所關(guān)心的話題,本文介紹mysql多表 update在實(shí)踐中幾種不同的寫法,需要的朋友可以參考下
    2012-12-12
  • mysql5.7 設(shè)置遠(yuǎn)程訪問的實(shí)現(xiàn)

    mysql5.7 設(shè)置遠(yuǎn)程訪問的實(shí)現(xiàn)

    這篇文章主要介紹了mysql5.7 設(shè)置遠(yuǎn)程訪問的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL無法讀表錯誤的解決方法(MySQL 1018 error)

    MySQL無法讀表錯誤的解決方法(MySQL 1018 error)

    這篇文章主要為大家詳細(xì)介紹了MySQL無法讀表錯誤的解決方法,MySQL 1018 error如何解決?具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu)

    K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu)

    這篇文章主要介紹了K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu),本次使用 OpenEBS 來作為存儲引擎,OpenEBS 是一個開源的、可擴(kuò)展的存儲平臺,它提供了一種簡單的方式來創(chuàng)建和管理持久化存儲卷,需要的朋友可以參考下
    2024-04-04
  • MySQL中一條update語句是如何執(zhí)行的

    MySQL中一條update語句是如何執(zhí)行的

    這篇文章主要給大家介紹了關(guān)于MySQL中一條update語句是如何執(zhí)行的相關(guān)資料,由于update涉及到數(shù)據(jù)的修改,所以很容易推斷,update語句比select語句會更復(fù)雜一些,需要的朋友可以參考下
    2022-03-03
  • 設(shè)置MySQLroot賬戶密碼報(bào)錯ERROR 1064 (42000): You have an error in your SQL syntax;的解決方案

    設(shè)置MySQLroot賬戶密碼報(bào)錯ERROR 1064 (42000): You 

    在安裝mysql的時(shí)候,設(shè)置root賬戶密碼出現(xiàn)了ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds..錯誤,本文小編給大家介紹了相關(guān)的解決方案,需要的朋友可以參考下
    2023-12-12
  • 詳解MySQL從入門到放棄-安裝

    詳解MySQL從入門到放棄-安裝

    這篇文章主要介紹了MySQL從入門到放棄-安裝,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評論