在MySQL中,restrict是約束的意思,是指對表中數據的一種限制,能夠幫助數據庫管理員更好地管理數據庫,并且能夠確保數據庫中數據的正確性、有效性和完整性。MySQL支持6種約束:主鍵約束、外鍵約束、唯一約束、檢查約束、非空約束和默認值約束。
restrict(約束)是指對表中數據的一種限制,能夠幫助數據庫管理員更好地管理數據庫,并且能夠確保數據庫中數據的正確性、有效性和完整性。
例如,在數據表中存放年齡的值時,如果存入 200、300 這些無效的值就毫無意義了。因此,使用約束來限定表中的數據范圍是很有必要的。
MySQL中的約束就是用來檢測數據正確性和合理性的,一般的錯誤有:1,存在相同重復的數據;2,錯誤的數據;3,數據丟失錯誤(空數據);4,指代不明確的錯誤(表之間無法準確聯系起來)等。
MySQL的約束就是用來解決上述問題的,比如身份證號不能重復,收貨地址不能空。如果違反了約束,則數據操作行為被制止。
在 MySQL 中,主要支持以下 6 種約束:
1)主鍵約束
主鍵約束是使用最頻繁的約束。在設計數據表時,一般情況下,都會要求表中設置一個主鍵。
主鍵是表的一個特殊字段,該字段能唯一標識該表中的每條信息。例如,學生信息表中的學號是唯一的。
2)外鍵約束
外鍵約束經常和主鍵約束一起使用,用來確保數據的一致性。
例如,一個水果攤,只有蘋果、桃子、李子、西瓜 4 種水果,那么,你來到水果攤要買水果只能選擇蘋果、桃子、李子和西瓜,不能購買其它的水果。
3)唯一約束
唯一約束與主鍵約束有一個相似的地方,就是它們都能夠確保列的唯一性。與主鍵約束不同的是,唯一約束在一個表中可以有多個,并且設置唯一約束的列是允許有空值的,雖然只能有一個空值。
例如,在用戶信息表中,要避免表中的用戶名重名,就可以把用戶名列設置為唯一約束。
4)檢查約束
檢查約束是用來檢查數據表中,字段值是否有效的一個手段。
例如,學生信息表中的年齡字段是沒有負數的,并且數值也是有限制的。如果是大學生,年齡一般應該在 18~30 歲之間。在設置字段的檢查約束時要根據實際情況進行設置,這樣能夠減少無效數據的輸入。
5)非空約束
非空約束用來約束表中的字段不能為空。例如,在學生信息表中,如果不添加學生姓名,那么這條記錄是沒有用的。
6)默認值約束
默認值約束用來約束當數據表中某個字段不輸入值時,自動為其添加一個已經設置好的值。
例如,在注冊學生信息時,如果不輸入學生的性別,那么會默認設置一個性別或者輸入一個“未知”。
默認值約束通常用在已經設置了非空約束的列,這樣能夠防止數據表在錄入數據時出現錯誤。
以上 6 種約束中,一個數據表中只能有一個主鍵約束,其它約束可以有多個。
1、給一張表添加主鍵約束
一張表的只能有一個主鍵,添加主鍵有兩種方式。
單一主鍵:使用一個列作為主鍵列,當該列的值有重復時,則違反唯一約束。
聯合主鍵:使用多個列作為主鍵列,當多個列的值都相同時,則違反唯一約束。指的是:使用多個列的組合形式來確定主鍵,當出現組合重復就無效,如00,01,10,11,12,22這樣的組合形式。
使用DDL語句添加主鍵約束。示例:
ALTERTABLE表名ADDPRIMARYKEY(列名);altertableempaddprimarykey(employee_id);//選取employee_id作為主鍵altertableempaddprimarykey(employee_id,shenfen_id);//聯合主鍵
2、給一張表添加自增長主鍵約束
auto_increment。數據庫管理系統自動維護表時自動加上的主鍵,利用自然數自增的方式確定主鍵。同樣的,自增長主鍵也是把某一列用作主鍵。當表中添加了主鍵的字段增加了數據,則主鍵自動加1。
自增長主鍵和一般主鍵約束可以相互轉化。
1, 一個表中只能有一個列為自動增長。2,自動增長的列的類型必須是整數類型。3,自動增長只能添加到具備主鍵約束與唯一性約束的列上。4,刪除主鍵約束或唯一性約束,如果該列擁有自動增長能力,則需要先去掉自動增長然后在刪除約束。
注意點:如果之前給某個字段添加了自增長屬性,則刪除這個字段時要先刪除自增長屬性。
altertable表名modify主鍵類型auto_increment;altertableempmodifyemployee_idintauto_increment;
或者在Navicat中添加主鍵:
3、刪除一張表中的主鍵約束
使用DDL語句刪除主鍵。
ALTERTABLE表名DROPPRIMARYKEY;altertableempdropprimarykey;
注意:刪除主鍵時,如果主鍵列具備自動增長能力,需要先去掉自動增長,然后在刪除主鍵。
altertableempmodifyemployee_idint;//去掉自增長,與添加自增長代碼地區別就是沒有auto_increamentaltertableempdropprimarykey;
4、給一張表添加外鍵約束
使用DDL語句添加外鍵約束??梢越o一張表設置多個外鍵。
ALTERTABLE表名ADDCONSTRAINT約束名FOREIGNKEY(列名)REFERENCES參照的表名(參照的列名);altertableempaddconstraintemp_fkforeignkey(dept_id)referencesdepartments(department_id);
或在在Navicat中添加外鍵。外鍵名稱常使用:表名_fk,表名_fk1表示。
5、刪除一張表的外鍵約束
使用DDL 語句刪除外鍵約束?;蛘咴贜avicat中主動刪除外鍵。
ALTERTABLE表名DROPFOREIGNKEY約束名;altertableempdropforeignkeyemp_fk;
6、給表中某字段添加唯一性約束
使用DDL語句添加唯一性約束?;蛟谠贜avicat中添加唯一性約束。
ALTERTABLE表名ADDCONSTRAINT約束名UNIQUE(列名);altertableempaddconstraintemp_ukunique(name);
7、刪除表中某字段的唯一性約束
使用DDL語句刪除唯一性約束。刪除之前需要弄清楚刪除的約束名是對哪一個字段進行約束的。
ALTERTABLE表名DROPKEY約束名;altertableempdropkeyemp_uk;
8、給表中某個字段添加非空約束
使用DDL語句添加非空約束?;蛘逳avicat。
ALTERTABLE表名MODIFY列名類型NOTNULL;altertableempmodifysalaryfloat(8,2)notNULL;
9、刪除表中某個字段的非空約束
使用DDL語句刪除非空約束。
ALTERTABLE表名MODIFY列名類型NULL;altertableempmodifysalaryfloat(8,2)NULL;
上面介紹了當一張表已經存在之后如何添加約束。下面介紹在一開始新建表的時候如何添加約束。
1、查詢表中加了哪些約束?
SHOWKEYSFROM表名;
2、創建表時添加約束
創建 depts 表包含 department_id 該列為主鍵且自動增長,department_name 列不允許重復,location_id 列不允含有空值。
createtabledepts(department_idintprimarykeyauto_increment,department_namevarchar(30)unique,location_idintnotnull;);
“mysql中restrict的含義是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注本站網站,小編將為大家輸出更多高質量的實用文章!
本文由 貴州做網站公司 整理發布,部分圖文來源于互聯網,如有侵權,請聯系我們刪除,謝謝!
c語言中正確的字符常量是用一對單引號將一個字符括起表示合法的字符常量。例如‘a’。數值包括整型、浮點型。整型可用十進制,八進制,十六進制。八進制前面要加0,后面...
2022年天津專場考試原定于3月19日舉行,受疫情影響確定延期,但目前延期后的考試時間推遲。 符合報名條件的考生,須在規定時間登錄招考資訊網(www.zha...
:喜歡聽,樂意看。指很受歡迎?!巴卣官Y料”喜聞樂見:[ xǐ wén lè jiàn ]詳細解釋1. 【解釋】:喜歡聽,樂意看。指很受歡迎。2. 【示例】:這是...
接力貸是什么意思?接力貸指的是某一位子女作為房屋的所有權人, 父母和該子女作為共同借款人,共銅貸款來購買住房的一種借貸產品。接力貸的申請條件是借款人需要具備穩定的收入來源,并且家庭月收入是接力貸月還款數額的2倍以上,同時指定某一個女是唯一 的連帶還款人。接力貸可以用公積金嗎?主貸人符合公積金貸款條件,共同借款人也符合公積金貸款條件,那么接力貸就可以申請公積金貸款。接力貸是子女申請房貸,父母雙方或者...
持有至到期投資的含義是什么?是指到期日固定、回收金額固定或可確定、企業有明確意圖和能力持有至到期的非衍生金融資產。一般情況下,企業持有并在活躍市場公開報價的政府債券、企業債券和金融債券,均可歸類為持有至到期投資。股權長期投資與持有至到期投資的區別?性質不同:長期股權投資會使投資者成為企業的所有者或股東,而持有至到期投資的投資者只是企業的債權人。公司虧損給股東,就是虧損,債權人不影響,照樣可以得到利...
歐洲債券和外國債券的區別是什么?1、外國債券一般是通過 市場所在國家的金融機構為主要承銷商組成承銷辛迪加承銷,而歐洲債券由多個國家的金融機構組成國際性承銷辛迪加承銷;2、外國債券是由市場所在國家的證券主管機構進行監管,公募發行則管理較為嚴格,需要向證券主管機構注冊并進行登記,發行后可申請在證券交易所上市;私募發行不需要注冊登記,但不能上市掛牌交易。歐洲債券發行時不用在債券面值貨幣國或發行市場所在地...