這是一項(xiàng)新功能,用于指定在插入或更新到一行之前檢查值的條件。如果表的任何行的搜索條件的結(jié)果為 FALSE,則約束可能返回錯(cuò)誤(但如果結(jié)果為 UNKNOWN 或 TRUE,則約束不會(huì)返回錯(cuò)誤)。此功能開(kāi)始在 MySQL 8.0.16 上運(yùn)行,在以前的版本中,我們可以創(chuàng)建它,但它不起作用,這意味著支持語(yǔ)法,但不起作用。要牢記的使用規(guī)則:
創(chuàng)新互聯(lián)公司是一家專注于網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),黃山網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)十載,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:黃山等地區(qū)。黃山做網(wǎng)站價(jià)格咨詢:028-86922220
AUTO_INCREMENT 自增列不允許使用
引用另一個(gè)表中的另一列不允許使用
存儲(chǔ)的函數(shù)和用戶定義的函數(shù)不允許使用
存儲(chǔ)過(guò)程和函數(shù)參數(shù)不允許使用
子查詢不允許使用
在外鍵中用于后續(xù)操作(ON UPDATE,ON DELETE)的列不允許使用
為下一條語(yǔ)句 INSERT,UPDATE,REPLACE,LOAD DATA 和 LOAD XML 評(píng)估此次監(jiān)測(cè)。此外,還會(huì)為 INSERT IGNORE,UPDATE IGNORE,LOAD DATA…IGNORE 和 LOAD XML…IGNORE 評(píng)估此監(jiān)測(cè)約束。對(duì)于這些語(yǔ)句,如果約束的評(píng)估結(jié)果為 FALSE,則會(huì)發(fā)生警告。插入或更新被跳過(guò)。
我們可以使用此功能在表中添加更多的邏輯,但是根據(jù)我以前作為程序員的經(jīng)驗(yàn),我不建議在表中添加邏輯,因?yàn)槌悄鸁o(wú)法訪問(wèn)應(yīng)用程序代碼,否則很難找到或調(diào)試錯(cuò)誤。
CREATE TABLE `dage` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(32) default '',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
CREATE TABLE `xiaodi` (
`id` int(11) NOT NULL auto_increment,
`dage_id` int(11) default NULL,
`name` varchar(32) default '',
PRIMARY KEY (`id`),
KEY `dage_id` (`dage_id`),
CONSTRAINT `xiaodi_ibfk_1` FOREIGN KEY (`dage_id`) REFERENCES `dage` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
1.外鍵的作用,主要有兩個(gè):
一個(gè)是讓數(shù)據(jù)庫(kù)自己通過(guò)外鍵來(lái)保證數(shù)據(jù)的完整性和一致性
一個(gè)就是能夠增加ER圖的可讀性
2.外鍵的配置
1)先創(chuàng)建一個(gè)主表,代碼如下:
#創(chuàng)建表student,并添加各種約束
create
table
student
(
id
int
primary
key
,
#主鍵約束
name
varchar(20)
,
#唯一約束
age
int
NOT
NULL,
#非空約束
sex
varchar(2)
,
address
varchar(20)
default
'重慶'
#默認(rèn)約束
)
;
再通過(guò)一個(gè)外鍵,創(chuàng)建一個(gè)分?jǐn)?shù)表,這樣的話,就可以方便查詢。代碼如下:
#創(chuàng)建分?jǐn)?shù)表
create
table
score
(
id
int
primary
key
,
sid
int
,
china
int
,
history
int,
english
int,
constraint
FK_sid
foreign
key(sid)
references
student(id)
#通過(guò)外鍵創(chuàng)建鏈接
)
;
創(chuàng)建外鍵的方法有很多,其中最常見(jiàn)創(chuàng)建外鍵的格式是:constraint
FK_***
foreign
key(**)
references
鏈接的外表
刪除外鍵:
alter
table
drop
foreign
key
'外鍵名'.
注意:
只有在定義外鍵時(shí),用constraint
外鍵名
foreign
key
....
方便進(jìn)行外鍵的刪除
一、Mysql支持以下約束:
※? 主鍵約束 :primary key
※? 唯一性約束:unique key
※? 外鍵約束:foreign key
※? 非空約束:not null
※? 默認(rèn)值約束:default
二、主鍵約束:
一個(gè)表只能有一個(gè)主鍵,當(dāng)建表時(shí)忘記設(shè)置主鍵約束時(shí).設(shè)置為主鍵的列查詢速度會(huì)非常快,所以一般會(huì)用聚集索引,這個(gè)我們后面會(huì)講到。
添加主鍵約束:設(shè)置myself表的age為主鍵
語(yǔ)法:alter? table 表名 add primary key;(列名)※? 可以有多個(gè)列名。
三、外鍵約束:
何為外鍵,當(dāng)建表時(shí)需要用到另外一個(gè)表的主鍵作為本表的的主鍵時(shí),需要設(shè)置外鍵。設(shè)置外間后,若想在刪除本表數(shù)據(jù)時(shí)會(huì)級(jí)聯(lián)刪除或者默認(rèn)刪除其他方式。
添加外鍵約束:設(shè)置本表的cno為外鍵
語(yǔ)法:alter table 表名稱 add foreign key (列名稱)? references? 關(guān)聯(lián)表名稱(列名稱);
四、非空約束:
當(dāng)插入新數(shù)據(jù)時(shí)對(duì)應(yīng)的列為不能空。非空約束是相對(duì)于默認(rèn)值約束而說(shuō)的。
添加非空約束:
語(yǔ)法:alter table 表名 modify 列名 列類型 not null;?
五、默認(rèn)值約束:default:
當(dāng)插入時(shí)沒(méi)有插入值時(shí),會(huì)自動(dòng)插入默認(rèn)值。默認(rèn)值約束相對(duì)于非空約束而說(shuō)。
添加默認(rèn)值約束:
語(yǔ)法:alter table 表名 add 列名 列類型 not null default '默認(rèn)值';
六、唯一性約束:
本列的內(nèi)容只能唯一不能重復(fù)。
添加唯一約束:
語(yǔ)法:alter table 列名 add unique(列名稱)? ※可以有多個(gè)列名稱,用逗號(hào)隔開(kāi)。
4.4.7添加約束
語(yǔ)句格式:ALTER TABLE 表名ADD? CONSTRAINT? 約束名 約束類型(字段名)
上面語(yǔ)句格式中,“表名”指定要添加約束的是哪個(gè)表,“ADD CONSTRAINT”表示要在表中增加約束,其后的“約束名”是擬增加約束的名字,“約束類型”是擬增加約束的類型,其后括號(hào)里的“字段名”是指約束是在哪一個(gè)字段上建立起來(lái)的。
下面截圖中的“ALTER TABLE”語(yǔ)句在t_dept表中新增加了一個(gè)約束名為unidept的約束,它是在對(duì)字段deptno進(jìn)行的唯一性約束。