SQL-约束

1.1 概念
- 约束是作用于表中列上的
规则,用于限制加入表的数据 - 约束的存在保证了数据库中数据的
正确性、有效性和完整性
1.2 分类
| 类型 | 描述 | 关键字 |
|---|---|---|
| 非空约束 | 保证列中所有的数据不能有null值 | NOT NULL |
| 唯一约束 | 保证列中所有数据各不相同 | UNIQUE |
| 主键约束 | 主键是一行数据的唯一标识,要求非空且唯一。 | PRIMARY KEY |
| 默认约束 | 保存数据时,未指定值则采用默认值 | DEFAULT |
| 外键约束 | 外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性 | FOREIGN KEY |
1.3 非空约束
-
概念
非空约束用于保证列中所有数据不能有NULL值
-
语法
-
添加约束
-- 创建表时添加非空约束 CREATE TABLE 表名( 列名 数据类型 NOT NULL, … );-- 建完表后添加非空约束 ALTER TABLE 表名 MODIFY 字段名 数据类型 NOT NULL; -
删除约束
ALTER TABLE 表名 MODIFY 字段名 数据类型;
-
1.4 唯一约束
-
概念
唯一约束用于保证列中所有数据各不相同
-
语法
-
添加约束
-- 创建表时添加唯一约束 CREATE TABLE 表名( 列名 数据类型 UNIQUE [AUTO_INCREMENT], -- AUTO_INCREMENT: 当不指定值时自动增长 … ); CREATE TABLE 表名( 列名 数据类型, … [CONSTRAINT] [约束名称] UNIQUE(列名) );-- 建完表后添加唯一约束 ALTER TABLE 表名 MODIFY 字段名 数据类型 UNIQUE; -
删除约束
ALTER TABLE 表名 DROP INDEX 字段名;
-
1.5 主键约束
-
概念
主键是一行数据的唯一标识,要求
非空且唯一一张表只能有一个主键
-
语法
-
添加约束
-- 创建表时添加主键约束 CREATE TABLE 表名( 列名 数据类型 PRIMARY KEY [AUTO_INCREMENT], … ); CREATE TABLE 表名( 列名 数据类型, [CONSTRAINT] [约束名称] PRIMARY KEY(列名) );-- 建完表后添加主键约束 ALTER TABLE 表名 ADD PRIMARY KEY(字段名); -
删除约束
ALTER TABLE 表名 DROP PRIMARY KEY;
-
1.6 默认约束
-
概念
保存数据时,未指定值则采用默认值
-
语法
-
添加约束
-- 创建表时添加默认约束 CREATE TABLE 表名( 列名 数据类型 DEFAULT 默认值, … );-- 建完表后添加默认约束 ALTER TABLE 表名 ALTER 列名 SET DEFAULT 默认值; -
删除约束
ALTER TABLE 表名 ALTER 列名 DROP DEFAULT;
-
1.7 外键约束
-
概念
外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性。
-
语法
-
添加外键约束
-- 创建表时添加外键约束 CREATE TABLE 表名( 列名 数据类型, … [CONSTRAINT] [外键名称] FOREIGN KEY(外键列名) REFERENCES 主表(主表列名) );-- 建完表后添加外键约束 ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称); -
删除约束
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
-



















