* 概念: 對錶中的數據進行限定,保證數據的正確性、有效性和完整性。 * 分類: 1. 主鍵約束:primary key 2. 非空約束:not null 3. 唯一約束:unique 4. 外鍵約束:foreign key * 非空約束:not null,值不能為null 1. 創建表時添加約束 ...
- 概念: 對錶中的數據進行限定,保證數據的正確性、有效性和完整性。
-
分類:
- 主鍵約束:primary key
- 非空約束:not null
- 唯一約束:unique
- 外鍵約束:foreign key
-
非空約束:not null,值不能為null
-
創建表時添加約束
CREATE TABLE stu(
id INT,
NAME VARCHAR(20) NOT NULL -- name為非空
); -
創建表完後,添加非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL; -
刪除name的非空約束
ALTER TABLE stu MODIFY NAME VARCHAR(20);
-
-
唯一約束:unique,值不能重覆
-
創建表時,添加唯一約束
CREATE TABLE stu(
id INT,
phone_number VARCHAR(20) UNIQUE -- 添加了唯一約束);
- 註意mysql中,唯一約束限定的列的值可以有多個null
-
刪除唯一約束
ALTER TABLE stu DROP INDEX phone_number;
-
在創建表後,添加唯一約束
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
-
-
主鍵約束:primary key。
-
註意:
- 含義:非空且唯一
- 一張表只能有一個欄位為主鍵
- 主鍵就是表中記錄的唯一標識
-
在創建表時,添加主鍵約束
create table stu(
id int primary key,-- 給id添加主鍵約束
name varchar(20)
); -
刪除主鍵
-- 錯誤 alter table stu modify id int ;
ALTER TABLE stu DROP PRIMARY KEY; -
創建完表後,添加主鍵
ALTER TABLE stu MODIFY id INT PRIMARY KEY; -
自動增長:
-
概念:如果某一列是數值類型的,使用 auto_increment 可以來完成值得自動增長
-
在創建表時,添加主鍵約束,並且完成主鍵自增長
create table stu(
id int primary key auto_increment,-- 給id添加主鍵約束
name varchar(20)
); -
刪除自動增長
ALTER TABLE stu MODIFY id INT; -
添加自動增長
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
-
-
-
外鍵約束:foreign key,讓表於表產生關係,從而保證數據的正確性。
-
在創建表時,可以添加外鍵
- 語法:
create table 表名(
....
外鍵列
constraint 外鍵名稱 foreign key (外鍵列名稱) references 主表名稱(主表列名稱)
);
- 語法:
-
刪除外鍵
ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名稱; -
創建表之後,添加外鍵
ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱 FOREIGN KEY (外鍵欄位名稱) REFERENCES 主表名稱(主表列名稱); -
級聯操作
- 添加級聯操作
語法:ALTER TABLE 表名 ADD CONSTRAINT 外鍵名稱
FOREIGN KEY (外鍵欄位名稱) REFERENCES 主表名稱(主表列名稱) ON UPDATE CASCADE ON DELETE CASCADE ; - 分類:
- 級聯更新:ON UPDATE CASCADE
- 級聯刪除:ON DELETE CASCADE
- 添加級聯操作
-
-