MySQL教程43-MySQL約束概述
在 MySQL 中,約束是指對錶中資料的一種約束,能夠幫助資料庫管理員更好地管理資料庫,並且能夠確保資料庫中資料的正確性和有效性。
例如,在資料表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的資料範圍是很有必要的。
在 MySQL 中,主要支援以下 6 種約束:
1)主鍵約束
主鍵約束是使用最頻繁的約束。在設計資料表時,一般情況下,都會要求表中設定一個主鍵而且主鍵不允許為null。
主鍵是表的一個特殊欄位,該欄位能唯一標識該表中的每條資訊。例如,學生資訊表中的學號是唯一的。
2)外來鍵約束
外來鍵約束經常和主鍵約束一起使用,用來確保資料的一致性。
例如,一個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那麼,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。
3)唯一約束
唯一約束與主鍵約束有一個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個表中可以有多個,並且設定唯一約束的列是允許有空值的,雖然只能有一個空值。
例如,在使用者資訊表中,要避免表中的使用者名稱重名,就可以把使用者名稱列設定為唯一約束。
4)檢查約束
檢查約束是用來檢查資料表中,欄位值是否有效的一個手段。
例如,學生資訊表中的年齡欄位是沒有負數的,並且數值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設定欄位的檢查約束時要根據實際情況進行設定,這樣能夠減少無效資料的輸入。
5)非空約束
非空約束用來約束表中的欄位不能為空。例如,在學生資訊表中,如果不新增學生姓名,那麼這條記錄是沒有用的。
6)預設值約束
預設值約束用來約束當資料表中某個欄位不輸入值時,自動為其新增一個已經設定好的值。
例如,在註冊學生資訊時,如果不輸入學生的性別,那麼會預設設定一個性別或者輸入一個“未知”。
預設值約束通常用在已經設定了非空約束的列,這樣能夠防止資料表在錄入資料時出現錯誤。
以上 6 種約束中,一個數據表中只能有一個主鍵約束,其它約束可以有多個。
接下來來了解具體的MySQL 中的約束... ...