1. 程式人生 > >SQL 的約束

SQL 的約束

輸入 允許 home 自用 因此 取值 都是 主鍵 prim

說明:文章所有內容均截選自用戶“實驗樓包工頭”發布在實驗樓上的教程【MySQL 基礎課程】,想要詳細的學習SQL,點擊教程即可免費學習了;未經允許,禁止轉載;

約束是一種限制,它通過對表的行或列的數據做出限制,來確保表的數據的完整性、唯一性。文章將在實踐操作中熟悉 MySQL 中的幾種約束。

1 約束分類

聽名字就知道,約束是一種限制,它通過對表的行或列的數據做出限制,來確保表的數據的完整性、唯一性。

在MySQL中,通常有這幾種約束:

約束類型: 主鍵 默認值 唯一 外鍵 非空
關鍵字: PRIMARY KEY DEFAULT UNIQUE FOREIGN KEY NOT NULL

2 建立含約束的表

為了方便介紹這幾種約束,我們先建立一個數據庫。

當然不用你一行一行地輸入命令搭建這個數據庫,實驗樓已經為你準備好了。首先打開 Xfce 終端,輸入命令進入 /home/shiyanlou/Desktop 目錄:

cd Desktop

使用 git 命令將需要的數據文件下載到本地文件夾:

git clone https://github.com/shiyanlou/SQL3

下載完成後,輸入命令開啟 MySQL 服務並使用 root 用戶登錄:

#打開 MySQL 服務
sudo service mysql start        

#使用 root 用戶登錄
mysql -u root                   

剛才下載的 SQL3 目錄下,有個文件 MySQL-03-01.sql,其中包含的代碼可以新建一個數據庫 mysql_shiyan,然後在其中創建三張表 departmentemployeeproject,它們包含了各種約束。

(SQL3 目錄在桌面上,你可以用Gedit查看裏面的 MySQL-03-01.sql 文件。)

加載文件中的數據,需要在 MySQL 控制臺中輸入命令:

source /home/shiyanlou/Desktop/SQL3/MySQL-03-01.sql;

查看一下這個數據庫,輸入命令 show tables;,可見:

技術分享圖片

3 主鍵

主鍵 (PRIMARY KEY)是用於約束表中的一行,作為這一行的唯一標識符,在一張表中通過主鍵就能準確定位到一行,因此主鍵十分重要。主鍵不能有重復且不能為空。

MySQL-03-01.sql 中,這裏有主鍵:

技術分享圖片

也可以這樣定義主鍵:

技術分享圖片

還有一種特殊的主鍵——復合主鍵。主鍵不僅可以是表中的一列,也可以由表中的兩列或多列來共同標識,比如:

技術分享圖片

4 默認值約束

默認值約束 (DEFAULT) 規定,當有 DEFAULT 約束的列,插入數據為空時,將使用默認值。

MySQL-03-01.sql 中,這段代碼包含了 DEFAULT 約束:

技術分享圖片

DEFAULT 約束只會在使用 INSERT 語句(上一實驗介紹過)時體現出來,INSERT語句中,如果被 DEFAULT 約束的位置沒有值,那麽這個位置將會被 DEFAULT 的值填充,如語句:

# 正常插入數據
INSERT INTO department(dpt_name,people_num) VALUES(‘dpt1‘,11);

#插入新的數據,people_num 為空,使用默認值
INSERT INTO department(dpt_name) VALUES(‘dpt2‘);  

輸入命令 SELECT * FROM department;,可見表中第二行的people_num 被 DEFAULT 的值 (10) 填充:

技術分享圖片

5 唯一約束

唯一約束 (UNIQUE) 比較簡單,它規定一張表中指定的一列的值必須不能有重復值,即這一列每個值都是唯一的。

MySQL-03-01.sql 中,也有 UNIQUE 約束:

技術分享圖片

當 INSERT 語句新插入的數據和已有數據重復的時候,如果有 UNIQUE約束,則 INSERT 失敗,比如:

INSERT INTO employee VALUES(01,‘Tom‘,25,3000,110110,‘dpt1‘);
INSERT INTO employee VALUES(02,‘Jack‘,30,3500,110110,‘dpt2‘); 

結果如圖:

技術分享圖片

6 外鍵約束

外鍵 (FOREIGN KEY) 既能確保數據完整性,也能表現表之間的關系。

一個表可以有多個外鍵,每個外鍵必須 REFERENCES (參考) 另一個表的主鍵,被外鍵約束的列,取值必須在它參考的列中有對應值。

技術分享圖片

在 INSERT 時,如果被外鍵約束的值沒有在參考列中有對應,比如以下命令,參考列 (department 表的 dpt_name) 中沒有dpt3,則INSERT 失敗:

INSERT INTO employee VALUES(02,‘Jack‘,30,3500,114114,‘dpt3‘);

可見之後將 dpt3 改為 dpt2(department 表中有 dpt2),則插入成功:

技術分享圖片

7 非空約束

非空約束 (NOT NULL),聽名字就能理解,被非空約束的列,在插入值時必須非空。

技術分享圖片

在MySQL中違反非空約束,不會報錯,只會有警告,比如以下語句:

#INSERT 成功 age 為空,因為沒有非空約束,表中顯示 NULL
INSERT INTO employee(id,name,salary,phone,in_dpt) VALUES(03,‘Jim‘,3400,119119,‘dpt2‘); 

#警告 salary 被非空約束,值為空,表中顯示0
INSERT INTO employee(id,name,age,phone,in_dpt) VALUES(04,‘Bob‘,23,123456,‘dpt1‘); 

結果如圖,出現警告,但還是插入數據成功,實驗樓的環境是 5.5.505.6 版本以上的 MySQL 會報錯,禁止插入不符合非空約束的數據:

技術分享圖片

此時 employee 表的內容為:

技術分享圖片

總結

文章通過一個數據庫實例了解了主鍵、默認值、外鍵、非空、唯一這幾種約束的特性,這幾種約束都是最常見的,需要仔細理解每種約束的含義及使用場景。

教程【MySQL 基礎課程】共17個實驗+3個挑戰,課程列表如下:

技術分享圖片
技術分享圖片
技術分享圖片

SQL 的約束