MySQL学习笔记4:完整性约束限制字段
完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果比如字段含有默认值,不能是NULL等如果插入的数据不满足限制要求,数据库管理系统就拒绝执行操作
完整性约束是对字段进行限制,从而符合该字段达到我们期望的效果比如字段含有默认值,不能是NULL等直观点说:如果插入的数据不满足限制要求,数据库管理系统就拒绝执行操作
设置表的主键
主键能够标识表中每条信息的唯一性,如同身份证号码和人的关系
人可以同名,但是身份证号码却是唯一的,
创建主键的目的在于快速查找到表中的某一条信息
单字段主键
代码如下:
mysql> create table student(
-> id int primary key,
-> name varchar(20),
-> sex boolean
-> );
Query OK, 0 rows affected (0.09 sec)
创建了三个字段,其中id为主键
多字段主键
多字段主键由多个属性组合而成,在属性定义完之后统一设置主键
代码如下:
mysql> create table student2(
-> id int,
-> course_id int,
-> score float,
-> primary key(id,course_id)
-> );
Query OK, 0 rows affected (0.11 sec)
student2表有三个字段,其中id和course_id的组合可以确定唯一的一条记录
设置表的外键
表的外键与主键是相对应的,比如表A中的id是外键,表B中的id是主键
那么就可以称表B为父表,表A为子表
设置表外键的作用在于建立与父表的联系,比如表B中id为123的学生删除后,表A中id为123的记录也随着消失
这样做的目的在于保证表的完整性
代码如下:
mysql> create table student3(
-> id int primary key,
-> course_id int,
-> teacher varchar(20),
-> constraint fk foreign key(id,course_id)
-> references student2(id,course_id)
-> );
Query OK, 0 rows affected (0.12 sec)
这里创建student3表,constraint后面的fk是外键别名,foreign key也就是设置外键的字段
references后的内容表示父表,和父表中的主键
需要注意的是,父表中的主键不能为空,并且主键和外键的数据类型要一致
设置表的非空约束
非空性很好理解,就是设置表中字段的值不能为空(NULL)
如果在已经设置此约束性条件的字段中插入空值,数据库系统则会报错
代码如下:
mysql> create table student4(
-> id int not null,
-> name varchar(20),
-> sex boolean
-> );
Query OK, 0 rows affected (0.10 sec)
这里的not null就是约束条件
设置表的唯一性约束
唯一性是指表中该字段的值不能重复出现,设置表的唯一性约束
也就是给表中某个字段加上unique
代码如下:
mysql> create table student5(
-> id int unique,
-> name varchar(20)
-> );
Query OK, 0 rows affected (0.10 sec)
此处id字段便不可重复
设置表的属性值自动增加
auto_increment主要用于为表中插入的新记录自动生成唯一的ID
一个表只能有一个字段使用auto_increment约束
并且该字段必须为主键的一部分
代码如下:
mysql> create table student6(
-> id int primary key auto_increment,
-> name varchar(20)
-> );
Query OK, 0 rows affected (0.12 sec)
这里的id是主键,并且会自动增加id值,比如1,2,3,4……
需要注意的是,auto_increment约束的值必须是整数类型
设置表中属性的默认值
在表中插入一条新的记录时,如果没有为该字段赋值
那么数据库系统会自动为该字段赋上一条默认值
代码如下:
mysql> create table student7(
-> id int primary key,
-> score int default 0
-> );
Query OK, 0 rows affected (0.10 sec)

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

標題:Windows11記憶體完整性已關閉,如何解決?隨著Windows11的推出,許多用戶都紛紛升級到了新系統。然而,有些使用者在使用Windows11時可能會遇到記憶體完整性關閉的問題,這會影響電腦的效能和穩定性。本文將針對Windows11記憶體完整性關閉的問題進行探討,並提供一些解決方法和建議。一、記憶體完整性關閉問題的原因Windows11中的內

學習Go語言中的資料庫函數並實作PostgreSQL資料的增刪改查操作在現代的軟體開發中,資料庫是不可或缺的一部分。 Go語言作為一門強大的程式語言,提供了豐富的資料庫操作函數和工具包,可以輕鬆實現資料庫的增刪改查操作。本文將介紹如何學習Go語言中的資料庫函數,並使用PostgreSQL資料庫進行實際的操作。第一步:安裝資料庫驅動程式在Go語言中,每個資料庫

在最近發布的Windows11作業系統中,微軟引進了一個新功能,即記憶體完整性。這項特性旨在提高系統安全性,保護使用者的隱私和資料免受惡意軟體的攻擊。然而,有時使用者可能會需要暫時關閉記憶體完整性,以便安裝一些特定的軟體或進行一些特殊操作。那麼,Windows11記憶體完整性關閉後,要如何開啟呢?首先,在Windows11中關閉記憶體完整性並不是一項簡單的操作,

如何透過微服務實現PHP功能的資料一致性與完整性?引言:隨著互聯網的快速發展和技術的不斷創新,微服務架構已成為當今最受歡迎的架構之一。作為一種建構獨立部署的小型服務的方法,微服務架構提供了許多優勢,如靈活性、可擴展性和獨立部署等。然而,當我們將PHP作為開發語言來實現微服務架構時,如何確保資料的一致性和完整性成為一項重要的任務。本文將介紹如何透過使用PHP的

標題:確認Oracle安裝是否完整有效的方法,需要具體程式碼範例隨著資訊科技的發展,資料庫管理系統已成為企業資料管理和處理的關鍵工具之一。 Oracle作為全球領先的關係型資料庫管理系統,在企業中被廣泛應用。然而,一個完整有效的Oracle安裝對於企業的資料管理和業務運作至關重要。本文將介紹如何確認Oracle安裝是否完整有效,同時提供具體的程式碼範例以協助管理

隨著網路技術的廣泛應用,資料安全問題越來越受到重視。對於資料庫中儲存的敏感信息,保證資料機密性和完整性至關重要。 MySql資料庫是一種開源的關聯式資料庫管理系統,其提供了多種加密技術來確保資料安全。 1.傳輸加密傳輸加密是透過對資料傳輸過程中所使用的網路連線進行加密來確保資料安全。對MySql資料庫來說,SSL和SSH代表了兩種主要的傳輸加密技術。 SSL(

如何使用MySQL的外鍵和約束來提高資料完整性和一致性?在MySQL資料庫中,外鍵和約束是兩個重要的概念,它們可以幫助提高資料的完整性和一致性。在本文中,我們將詳細討論如何使用MySQL的外鍵和限制來實現這個目標,並提供一些程式碼範例。一、外鍵的概念和作用外鍵是用來建立表之間的關聯關係的一種機制,它可以確保資料在相關表之間的一致性。外鍵通常由一個表的主鍵(或唯一

隨著web應用程式的不斷發展,PHP已成為最廣泛使用的伺服器端腳本語言之一。在PHP開發過程中,為了實現高效、可維護和可擴展的程式碼規格是不可或缺的。本篇文章將介紹PHP如何進行程式碼規範約束,以確保程式碼風格一致且易於理解,進而提升團隊內部協作和對外交付的品質。一、PSR標準PHP編程規範(PHPStandardRecommendations)簡稱P
