發布時間: 2023-02-16 17:07:12
在 MySQL 中,約束是指對表中數據的一種約束,能夠幫助數據庫管理員更好地管理數據庫,并且能夠確保數據庫中數據的正確性和有效性。 例如,在數據表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的數據范圍是很有必要的。 在 MySQL 中,主要支持以下 6 種約束:
1、主鍵約束
主鍵約束是使用最頻繁的約束。在設計數據表時,一般情況下,都會要求表中設置一個主鍵。主鍵是表的一個特殊字段,該字段能唯一標識該表中的每條信息。例如,學生信息表中的學號是唯一的。
2、外鍵約束
外鍵約束經常和主鍵約束一起使用,用來確保數據的一致性。例如,一個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那么,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。
3、唯一約束
唯一約束與主鍵約束有一個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個表中可以有多個,并且設置唯一約束的列是允許有空值的,雖然只能有一個空值。例如,在用戶信息表中,要避免表中的用戶名重名,就可以把用戶名列設置為唯一約束。
4、檢查約束
檢查約束是用來檢查數據表中,字段值是否有效的一個手段。例如,學生信息表中的年齡字段是沒有負數的,并且數值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設置字段的檢查約束時要根據實際情況進行設置,這樣能夠減少無效數據的輸入。
5、非空約束
非空約束用來約束表中的字段不能為空。例如,在學生信息表中,如果不添加學生姓名,那么這條記錄是沒有用的。
6、默認值約束
默認值約束用來約束當數據表中某個字段不輸入值時,自動為其添加一個已經設置好的值。例如,在注冊學生信息時,如果不輸入學生的性別,那么會默認設置一個性別或者輸入一個“未知”。
上一篇: 華為GaussDB數據庫認證產品更名公告
下一篇: cisp考試時間上海2023年最新