4.4.7添加約束
公司主營業(yè)務:網(wǎng)站設計制作、網(wǎng)站設計、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出臨桂免費做網(wǎng)站回饋大家。
語句格式:ALTER TABLE 表名ADD? CONSTRAINT? 約束名 約束類型(字段名)
上面語句格式中,“表名”指定要添加約束的是哪個表,“ADD CONSTRAINT”表示要在表中增加約束,其后的“約束名”是擬增加約束的名字,“約束類型”是擬增加約束的類型,其后括號里的“字段名”是指約束是在哪一個字段上建立起來的。
下面截圖中的“ALTER TABLE”語句在t_dept表中新增加了一個約束名為unidept的約束,它是在對字段deptno進行的唯一性約束。
這是一項新功能,用于指定在插入或更新到一行之前檢查值的條件。如果表的任何行的搜索條件的結果為 FALSE,則約束可能返回錯誤(但如果結果為 UNKNOWN 或 TRUE,則約束不會返回錯誤)。此功能開始在 MySQL 8.0.16 上運行,在以前的版本中,我們可以創(chuàng)建它,但它不起作用,這意味著支持語法,但不起作用。要牢記的使用規(guī)則:
AUTO_INCREMENT 自增列不允許使用
引用另一個表中的另一列不允許使用
存儲的函數(shù)和用戶定義的函數(shù)不允許使用
存儲過程和函數(shù)參數(shù)不允許使用
子查詢不允許使用
在外鍵中用于后續(xù)操作(ON UPDATE,ON DELETE)的列不允許使用
為下一條語句 INSERT,UPDATE,REPLACE,LOAD DATA 和 LOAD XML 評估此次監(jiān)測。此外,還會為 INSERT IGNORE,UPDATE IGNORE,LOAD DATA…IGNORE 和 LOAD XML…IGNORE 評估此監(jiān)測約束。對于這些語句,如果約束的評估結果為 FALSE,則會發(fā)生警告。插入或更新被跳過。
我們可以使用此功能在表中添加更多的邏輯,但是根據(jù)我以前作為程序員的經(jīng)驗,我不建議在表中添加邏輯,因為除非您無法訪問應用程序代碼,否則很難找到或調(diào)試錯誤。
一、Mysql支持以下約束:
※? 主鍵約束 :primary key
※? 唯一性約束:unique key
※? 外鍵約束:foreign key
※? 非空約束:not null
※? 默認值約束:default
二、主鍵約束:
一個表只能有一個主鍵,當建表時忘記設置主鍵約束時.設置為主鍵的列查詢速度會非??欤砸话銜镁奂饕?,這個我們后面會講到。
添加主鍵約束:設置myself表的age為主鍵
語法:alter? table 表名 add primary key;(列名)※? 可以有多個列名。
三、外鍵約束:
何為外鍵,當建表時需要用到另外一個表的主鍵作為本表的的主鍵時,需要設置外鍵。設置外間后,若想在刪除本表數(shù)據(jù)時會級聯(lián)刪除或者默認刪除其他方式。
添加外鍵約束:設置本表的cno為外鍵
語法:alter table 表名稱 add foreign key (列名稱)? references? 關聯(lián)表名稱(列名稱);
四、非空約束:
當插入新數(shù)據(jù)時對應的列為不能空。非空約束是相對于默認值約束而說的。
添加非空約束:
語法:alter table 表名 modify 列名 列類型 not null;?
五、默認值約束:default:
當插入時沒有插入值時,會自動插入默認值。默認值約束相對于非空約束而說。
添加默認值約束:
語法:alter table 表名 add 列名 列類型 not null default '默認值';
六、唯一性約束:
本列的內(nèi)容只能唯一不能重復。
添加唯一約束:
語法:alter table 列名 add unique(列名稱)? ※可以有多個列名稱,用逗號隔開。