千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > MySQL有哪些約束

MySQL有哪些約束

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-12-02 23:04:03 1701529443

在 MySQL 中,約束是指對表中數(shù)據(jù)的一種約束,能夠幫助數(shù)據(jù)庫管理員更好地管理數(shù)據(jù)庫,并且能夠確保數(shù)據(jù)庫中數(shù)據(jù)的正確性和有效性。 例如,在數(shù)據(jù)表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的數(shù)據(jù)范圍是很有必要的。 在 MySQL 中,主要支持以下 6 種約束:

1、主鍵約束

主鍵約束是使用最頻繁的約束。在設計數(shù)據(jù)表時,一般情況下,都會要求表中設置一個主鍵。主鍵是表的一個特殊字段,該字段能唯一標識該表中的每條信息。例如,學生信息表中的學號是唯一的。

2、外鍵約束

外鍵約束經(jīng)常和主鍵約束一起使用,用來確保數(shù)據(jù)的一致性。例如,一個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那么,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。

3、唯一約束

唯一約束與主鍵約束有一個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個表中可以有多個,并且設置唯一約束的列是允許有空值的,雖然只能有一個空值。例如,在用戶信息表中,要避免表中的用戶名重名,就可以把用戶名列設置為唯一約束。

4、檢查約束

檢查約束是用來檢查數(shù)據(jù)表中,字段值是否有效的一個手段。例如,學生信息表中的年齡字段是沒有負數(shù)的,并且數(shù)值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設置字段的檢查約束時要根據(jù)實際情況進行設置,這樣能夠減少無效數(shù)據(jù)的輸入。

5、非空約束

非空約束用來約束表中的字段不能為空。例如,在學生信息表中,如果不添加學生姓名,那么這條記錄是沒有用的。

6、默認值約束

默認值約束用來約束當數(shù)據(jù)表中某個字段不輸入值時,自動為其添加一個已經(jīng)設置好的值。例如,在注冊學生信息時,如果不輸入學生的性別,那么會默認設置一個性別或者輸入一個“未知”。

tags: IT培訓
聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
嵌入式培訓課程:探索技術的無限可能

近年來,嵌入式系統(tǒng)的廣泛應用已經(jīng)深刻改變了我們的生活方式。從智能手機到智能家居,從汽車到醫(yī)療設備,嵌入式技術已經(jīng)成為現(xiàn)代社會不可或缺的...詳情>>

2023-12-12 11:02:35
嵌入式開發(fā):Linux網(wǎng)絡編程的探索與實踐

在當今的科技世界中,嵌入式系統(tǒng)已經(jīng)滲透到我們生活的方方面面,從智能手機、電視、汽車到醫(yī)療設備等。而在這些設備中,Linux網(wǎng)絡編程扮演著至...詳情>>

2023-12-12 09:55:55
Java游戲項目開發(fā):技術概覽與實踐

在數(shù)字化世界中,游戲已經(jīng)成為了人們休閑娛樂的重要方式之一。隨著科技的不斷進步,游戲開發(fā)行業(yè)也在不斷發(fā)展,而Java作為一門廣泛使用的編程語...詳情>>

2023-12-12 08:49:15
Web前端的基石:HTML

在數(shù)字化的時代,網(wǎng)頁設計已經(jīng)成為了一個重要的領域。而在這個領域中,HTML(HyperTextMarkupLanguage)無疑是最基礎、最重要的一環(huán)。它是構建...詳情>>

2023-12-12 08:15:55
嵌入式開發(fā):內存分配的方式

嵌入式系統(tǒng)開發(fā)中,內存分配是一個至關重要的話題。嵌入式系統(tǒng)通常具有有限的內存資源,因此合理的內存分配方式對系統(tǒng)的性能和穩(wěn)定性至關重要。...詳情>>

2023-12-12 06:35:55