約束的基本概念
概念:對表中數據進行限定,保證數據的正確性,有效性和完整性
約束的分類
- 主鍵約束:primary key
- 非空約束:not null
- 唯一約束:unique
- 外鍵約束:foreign ke
非空約束:not null
- 創建表時添加約束
CREATE TABLE stu(
id INT,
NAME VARCHAR(20) NOT NULL
);
2.創建表完后,添加非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;
3.刪除name的非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20);
唯一約束:unique
唯一約束是指某一列的值不能重復
注意:唯一約束可以有null值,但是只能有一條記錄為null
1.在創建表時,添加唯一約束
CREATE TABLE stu(
id INT,
phone_number VARCHAR(20) UNIQUE
);
2.刪除唯一約束
Alter table stu drop index phone_number;
3.在表創建完后,添加唯一約束
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
主鍵約束:primary key
注意事項:
1.含義:非空且唯一
2.一張表只能有一個字段為主鍵
3.主鍵就是表中記錄的唯一標識
具體用法:
1.在創建表時,添加主鍵約束
Create table stu(
Id int primary key, -- 給id添加主鍵約束
Name varchar(20)
);
2.刪除主鍵
ALTER TABLE stu MODIFY Id INT; -- 錯誤的寫法
ALTER TABLE stu DROP PRIMARY KEY; -- 正確的寫法
3.創建完表后,添加主鍵
ALTER TABLE stu MODIFY Id INT PRIMARY KEY;
自動增長
概念:
如果某一列是數值類型的,使用aotu_increment 可以來完成值得自動增長。
用法舉例:
1. 在創建表時,添加主鍵約束,并且完成主鍵自動增長。
Create table stu(
Id int primary key auto_increment, -- 給id添加主鍵約束
Name varchar(20)
);
2.刪除自動增長
ALTER TABLE stu MODIFY id INT ;
3.添加自動增長
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
外鍵約束:foreign key
作用:
讓表與表產生關系,從而保證數據的正確性。
用法舉例:
1.在創建表時,可以添加外鍵
語法:create table 表名(
….
外鍵列
Constraint 外鍵名稱 foreign key 外鍵列名稱 references 主表名稱(主表列名稱)
);
2.刪除外鍵
ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱;
3.創建表之后,添加外鍵
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱);
級聯操作
1.添加級聯的操作
語法:
-- 添加外鍵
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵字段名稱) REFERENCES 主表名稱(主表列名稱) ON UPDATE CASCADE ON DELETE CASCADE ;
2.分類
1.級聯更新:ON UPDATE CASCADE
2.級聯刪除:ON DELETE CASCADE