新聞中心

例如,在數(shù)據(jù)表中存放年齡的值時(shí),如果存入 200、300 這些無(wú)效的值就毫無(wú)意義了。因此,使用約束來(lái)限定表中的數(shù)據(jù)范圍是很有必要的。
在 MySQL 中,主要支持以下 6 種約束:
1)主鍵約束
主鍵約束是使用最頻繁的約束。在設(shè)計(jì)數(shù)據(jù)表時(shí),一般情況下,都會(huì)要求表中設(shè)置一個(gè)主鍵。
主鍵是表的一個(gè)特殊字段,該字段能唯一標(biāo)識(shí)該表中的每條信息。例如,學(xué)生信息表中的學(xué)號(hào)是唯一的。
2)外鍵約束
外鍵約束經(jīng)常和主鍵約束一起使用,用來(lái)確保數(shù)據(jù)的一致性。
例如,一個(gè)水果攤,只有蘋(píng)果、桃子、李子、西瓜 4 種水果,那么,你來(lái)到水果攤要買水果只能選擇蘋(píng)果、桃子、李子和西瓜,不能購(gòu)買其它的水果。
3)唯一約束
唯一約束與主鍵約束有一個(gè)相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個(gè)表中可以有多個(gè),并且設(shè)置唯一約束的列是允許有空值的,雖然只能有一個(gè)空值。
例如,在用戶信息表中,要避免表中的用戶名重名,就可以把用戶名列設(shè)置為唯一約束。
4)檢查約束
檢查約束是用來(lái)檢查數(shù)據(jù)表中,字段值是否有效的一個(gè)手段。
例如,學(xué)生信息表中的年齡字段是沒(méi)有負(fù)數(shù)的,并且數(shù)值也是有限制的。如果是大學(xué)生,年齡一般應(yīng)該在 18~30 歲之間。在設(shè)置字段的檢查約束時(shí)要根據(jù)實(shí)際情況進(jìn)行設(shè)置,這樣能夠減少無(wú)效數(shù)據(jù)的輸入。
5)非空約束
非空約束用來(lái)約束表中的字段不能為空。例如,在學(xué)生信息表中,如果不添加學(xué)生姓名,那么這條記錄是沒(méi)有用的。
6)默認(rèn)值約束
默認(rèn)值約束用來(lái)約束當(dāng)數(shù)據(jù)表中某個(gè)字段不輸入值時(shí),自動(dòng)為其添加一個(gè)已經(jīng)設(shè)置好的值。
例如,在注冊(cè)學(xué)生信息時(shí),如果不輸入學(xué)生的性別,那么會(huì)默認(rèn)設(shè)置一個(gè)性別或者輸入一個(gè)“未知”。
默認(rèn)值約束通常用在已經(jīng)設(shè)置了非空約束的列,這樣能夠防止數(shù)據(jù)表在錄入數(shù)據(jù)時(shí)出現(xiàn)錯(cuò)誤。
由于篇幅有限,我們?cè)谝韵挛恼轮性敿?xì)講解 MySQL 中的約束。
- MySQL主鍵約束
- MySQL外鍵約束
- MySQL唯一約束
- MySQL檢查約束
- MySQL默認(rèn)值約束
- MySQL非空約束
網(wǎng)站名稱:MySQL約束概述
URL鏈接:http://m.5511xx.com/article/djiohcj.html


咨詢
建站咨詢
