目錄
- MySQL約束操作
- 1.非空約束
- 2.唯一約束
- 3.主鍵約束
- 4.外鍵約束
- 5、級聯(lián)
MySQL約束操作
概念:對表中的數(shù)據(jù)進行限定,保證數(shù)據(jù)的正確性,有效性和完整性。
分類:
- 主鍵:
primary key
- 非空約束:
not null
- 唯一約束:
unique
- 外鍵約束:
foreign key
1.非空約束
not null
,值不能為空。
創(chuàng)建表時添加非空約束:
CREATE TABLE stu(
id INT,
NAME VARCHAR(20) NOT NULL
);
創(chuàng)建表完后,添加非空約束
ALTER TABLE stu
MODIFY NAME VARCHAR(20) NOT NULL;
刪除非空約束
ALTER TABLE stu
MODIFY NAME VARCHAR(20);
2.唯一約束
unique,
值不能重復。
創(chuàng)建表時添加唯一約束
CREATE stu(
id INT;
phone_number VARCHAR(20) UNIQUE
);
注意:mysql
中,唯一約束限定的列的值可以有多個null
。
刪除唯一約束
ALTER TABLE stu
DROP INDEX phone_number;
創(chuàng)建表完后,添加唯一約束
ALTER TABLE stu
MODIFY phone_number VARCHAR(20) UNIQUE;
3.主鍵約束
primary key,
- 非空且唯一。
- 一張表只能有一個字段為主鍵。
- 主鍵就是表中記錄的唯一標識。
創(chuàng)建表時添加主鍵約束
CREATE TABLE stu(
id INT PRIMARY KEY,
NAME VARCHAR(20)
);
刪除主鍵
ALTER TABLE stu
DROP PRIMARY KEY;
創(chuàng)建表完后,添加主鍵
ALTER TABLE stu
MODIFY id INT PRIMARY KEY ;
這里補充一個知識點:自動增長
概念:如果某一列是數(shù)值類型的,使用auto_increment
可以來完成自動增長。
例子:
在創(chuàng)建表時,添加主鍵約束,并且完成主鍵自動增長
CREATE TABLE stu(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20)
);
#自動增長會根據(jù)當前列的最后一行的值往后增加。
刪除自動增長
ALTER TABLE stu
MODIFY id INT;
#這樣只會刪除自動增長,主鍵刪不掉。
創(chuàng)建表完后,在添加自動增長
ALTER TABLE stu
MODIFY id INT AUTO_INCREMENT;
4.外鍵約束
foreign ley
,讓表與表產(chǎn)生關系,從而保證數(shù)據(jù)的正確性。
在創(chuàng)建表時,可以添加外鍵
CREATE TABLE 表名(
...
外鍵列
CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵列名稱) REFERENCES 主表名稱(主表列名稱)
);
刪除外鍵
ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱;
創(chuàng)建表之后,添加外鍵
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱);
5、級聯(lián)
添加級聯(lián)操作
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱
FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱)
ON UPDATE CASCADE ON DELETE CASCADE ;
級聯(lián)刪除
到此這篇關于MySQL約束超詳解的文章就介紹到這了,更多相關MySQL約束內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- mysql完整性約束實例詳解
- MySQL中常見的六個約束類型詳解
- MySQL約束類型及舉例介紹
- 基于MySQL數(shù)據(jù)庫的數(shù)據(jù)約束實例及五種完整性約束介紹
- MySQL學習之數(shù)據(jù)庫表五大約束詳解小白篇