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

MySQL中約束的實現(xiàn)示例

 更新時間:2024年03月28日 10:26:47   作者:嶼小夏  
本文主要介紹了MySQL中約束的實現(xiàn)示例,包括非空約束、唯一約束、主鍵約束、默認約束、檢查約束和外鍵約束,具有一定的參考價值,感興趣的可以了解一下

前言

數(shù)據(jù)庫中的約束是確保數(shù)據(jù)完整性和準確性的重要手段。通過對數(shù)據(jù)表字段的約束設置,可以限制數(shù)據(jù)的取值范圍、確保數(shù)據(jù)的唯一性以及建立表與表之間的關聯(lián)關系。本文將深入介紹MySQL中的各種約束類型及其使用方法,包括非空約束、唯一約束、主鍵約束、默認約束、檢查約束和外鍵約束,以及如何在創(chuàng)建表和修改表時添加約束,以及外鍵約束的相關知識。

一. 約束概述

概念:約束是作用于表中字段上的規(guī)則,用于限制存儲在表中的數(shù)據(jù)。

目的:保證數(shù)據(jù)庫中數(shù)據(jù)的正確、有效性和完整性。

分類:

約束描述關鍵字
非空約束限制該字段的數(shù)據(jù)不能為nullNOT NULL
唯一約束保證該字段的所有數(shù)據(jù)都是唯一、不重復的UNIQUE
主鍵約束主鍵是一行數(shù)據(jù)的唯一標識,要求非空且唯一PRIMARY KEY
默認約束保存數(shù)據(jù)時,如果未指定該字段的值,則采用默認值DEFAULT
檢查約束(8.0.16版本 之后)保證字段值滿足某一個條件CHECK
外鍵約束用來讓兩張表的數(shù)據(jù)之間建立連接,保證數(shù)據(jù)的一致 性和完整性FOREIGN KEY

注意:約束是作用于表中字段上的,可以在創(chuàng)建表/修改表的時候添加約束 。

二. 約束演示

如何在創(chuàng)建表、修改表的時候來指定約束呢,接下來我們就通過一個案例,來演示一下。

字段名字段含 義字段類型約束條件約束關鍵字
idID唯一 標識int主鍵,并且自動增長PRIMARY KEY, AUTO_INCREMENT
name姓名varchar(10)不為空,并且唯一NOT NULL , UNIQUE
age年齡int大于0,并且小于等 于120CHECK
status狀態(tài)char(1)如果沒有指定該值, 默認為1DEFAULT
gender性別char(1)

對應的建表語句為:

CREATE TABLE tb_user(
	id int AUTO_INCREMENT PRIMARY KEY COMMENT 'ID唯一標識',
	name varchar(10) NOT NULL UNIQUE COMMENT '姓名' ,
	age int check (age > 0 && age <= 120) COMMENT '年齡' ,
	status char(1) default '1' COMMENT '狀態(tài)',
	gender char(1) COMMENT '性別'
);	

在為字段添加約束時,我們只需要在字段之后加上約束的關鍵字即可,需要關注其語法。我們執(zhí)行上面的SQL把表結構創(chuàng)建完成,然后接下來,就可以通過一組數(shù)據(jù)進行測試,從而驗證一下,約束是否可以生效。

insert into tb_user(name,age,status,gender) values ('Tom1',19,'1','男'),
('Tom2',25,'0','男');
insert into tb_user(name,age,status,gender) values ('Tom3',19,'1','男');
insert into tb_user(name,age,status,gender) values (null,19,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom3',19,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom4',80,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom5',-1,'1','男');
insert into tb_user(name,age,status,gender) values ('Tom5',121,'1','男');
insert into tb_user(name,age,gender) values ('Tom5',120,'男');

三. 外鍵約束

3.1 介紹

外鍵:用來讓兩張表的數(shù)據(jù)之間建立連接,從而保證數(shù)據(jù)的一致性和完整性。

我們來看一個例子:

image-20231220104217784

左側的emp表是員工表,里面存儲員工的基本信息,包含員工的ID、姓名、年齡、職位、薪資、入職日期、上級主管ID、部門ID,在員工的信息中存儲的是部門的ID dept_id,而這個部門的ID是關聯(lián)的部門表dept的主鍵id,那emp表的dept_id就是外鍵,關聯(lián)的是另一張表的主鍵。

注意

目前上述兩張表,只是在邏輯上存在這樣一層關系;在數(shù)據(jù)庫層面,并未建立外鍵關聯(lián),所以是無法保證數(shù)據(jù)的一致性和完整性的。

3.2 語法

添加外鍵

CREATE TABLE 表名(
	字段名 數(shù)據(jù)類型,
	...
	[CONSTRAINT] [外鍵名稱] FOREIGN KEY (外鍵字段名) REFERENCES 主表 (主表列名)
);
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名)REFERENCES 主表 (主表列名) ;

刪除外鍵

ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱;

3.3 刪除/更新行為

添加了外鍵之后,再刪除父表數(shù)據(jù)時產(chǎn)生的約束行為,我們就稱為刪除/更新行為。具體的刪除/更新行為有以下幾種:

行為說明
NO ACTION當在父表中刪除/更新對應記錄時,首先檢查該記錄是否有對應外鍵,如果有則不 允許刪除/更新。 (與 RESTRICT 一致) 默認行為
RESTRICT當在父表中刪除/更新對應記錄時,首先檢查該記錄是否有對應外鍵,如果有則不 允許刪除/更新。 (與 NO ACTION 一致) 默認行為
CASCADE當在父表中刪除/更新對應記錄時,首先檢查該記錄是否有對應外鍵,如果有,則 也刪除/更新外鍵在子表中的記錄。
SET NULL當在父表中刪除對應記錄時,首先檢查該記錄是否有對應外鍵,如果有則設置子表 中該外鍵值為null(這就要求該外鍵允許取null)。
SET DEFAULT父表有變更時,子表將外鍵列設置成一個默認的值 (Innodb不支持)

具體語法為:

ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;

???全篇總結

本文詳細介紹了MySQL中的各種約束類型及其語法,包括約束的概念、分類、使用方法和外鍵約束的相關知識。通過學習本文,讀者可以掌握如何在數(shù)據(jù)庫設計和管理中靈活運用約束,從而保證數(shù)據(jù)的完整性和準確性,提高數(shù)據(jù)庫的穩(wěn)定性和安全性。

到此這篇關于MySQL中約束的實現(xiàn)示例的文章就介紹到這了,更多相關MySQL 約束內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 與MSSQL對比學習MYSQL的心得(二)--顯示寬度

    與MSSQL對比學習MYSQL的心得(二)--顯示寬度

    MYSQL中的整數(shù)型數(shù)據(jù)類型都可以指定顯示寬度,而SQLSERVER不行
    2014-06-06
  • MySQL 5.5的max_allowed_packet屬性的修改方法

    MySQL 5.5的max_allowed_packet屬性的修改方法

    今天在部署一個實驗系統(tǒng)的時候,報錯提示需要修改一下MySQL的配置文件,在修改的時候是有技巧的,大家可以參考下本文嘗試操作下
    2013-08-08
  • Windows 10系統(tǒng)下徹底刪除卸載MySQL的方法教程

    Windows 10系統(tǒng)下徹底刪除卸載MySQL的方法教程

    mysql數(shù)據(jù)庫的重新安裝是一個麻煩的問題,很難卸除干凈,下面這篇文章主要給大家介紹了關于在Windows 10系統(tǒng)下徹底刪除卸載MySQL的方法教程,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • C#編寫方法實例

    C#編寫方法實例

    在下面的練習中,將創(chuàng)建一個應用程序,它包含的一個方法能夠計算一名顧問的收費金額——假定該顧問每天收取固定的費用,將根據(jù)工作了多少天來收費。首先要開發(fā)應用程序的邏輯,然后利用“生成方法存根向導”來寫出這個邏輯使用的方法。接著,我們將在一個控制臺應用程序中運行方法,以獲得對該程序的最終印象。最后,我們將使用Visual Studio 2005調試器來檢查方法調用。
    2008-04-04
  • MySQL數(shù)據(jù)庫如何開啟遠程連接(多備份)

    MySQL數(shù)據(jù)庫如何開啟遠程連接(多備份)

    多備份服務器在備份你的數(shù)據(jù)庫時,必須能夠遠程連接上你的數(shù)據(jù)庫。但是一般來說mysql安裝時都是關閉遠程連接的,因此,需要你開通mysql數(shù)據(jù)庫的遠程訪問權限。那么如何開啟呢
    2015-01-01
  • 詳細分析mysql MDL元數(shù)據(jù)鎖

    詳細分析mysql MDL元數(shù)據(jù)鎖

    這篇文章主要介紹了mysql MDL元數(shù)據(jù)鎖的相關資料,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-08-08
  • 解決mysql的int型主鍵自增問題

    解決mysql的int型主鍵自增問題

    這篇文章主要介紹了解決mysql的int型主鍵自增問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 解析mysql中的auto_increment的問題

    解析mysql中的auto_increment的問題

    本篇文章是對mysql中的auto_increment的問題進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • CentOS安裝mysql5.7 及簡單配置教程詳解

    CentOS安裝mysql5.7 及簡單配置教程詳解

    這篇文章主要介紹了CentOS安裝mysql5.7 及簡單配置教程詳解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • 聊一聊MyISAM和InnoDB的區(qū)別

    聊一聊MyISAM和InnoDB的區(qū)別

    這篇文章主要介紹了聊一聊MyISAM和InnoDB的區(qū)別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08

最新評論