20.约束

分类:

| 约束             | 描述                           | 关键字         |
| -------------- | ---------------------------- | ----------- |
| 非空约束           | 限制该字段的数据不能为null              | NOT NULL    |
| 唯一约束           | 保证该字段的所有数据都是唯一、不重复的          | UNIQUE      |
| 主键约束           | 主键是一行数据的唯一标识,要求非空且唯一         | PRIMARY KEY |
| 默认约束           | 保存数据时,如果未指定该字段的值,则采用默认值      | DEFAULT     |
| 检查约束(8.0.1版本后) | 保证字段值满足某一个条件                 | CHECK       |
| 外键约束           | 用来让两张图的数据之间建立连接,保证数据的一致性和完整性 | FOREIGN KEY |

约束是作用于表中字段上的,可以再创建表/修改表的时候添加约束
例子:

create table user(
	id int primary key auto_increment,
	name varchar(10) not null unique,
	age int check(age > 0 and age < 120),
	status char(1) default '1',
	gender char(1)
);

常用约束

| 约束条件 | 关键字            |
| ---- | -------------- |
| 主键   | PRIMARY KEY    |
| 自动增长 | AUTO_INCREMENT |
| 不为空  | NOT NULL       |
| 唯一   | UNIQUE         |
| 逻辑条件 | CHECK          |
| 默认值  | DEFAULT        |

例子:

create table user(
	id int primary key auto_increment,
	name varchar(10) not null unique,
	age int check(age > 0 and age < 120),
	status char(1) default '1',
	gender char(1)
);

外键约束
添加外键:

CREATE TABLE 表名(
	字段名 字段类型,
	...
	[CONSTRAINT] [外键名称] FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名)
);
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表(主表列名);

-- 例子
alter table emp add constraint fk_emp_dept_id foreign key(dept_id) references dept(id);

删除外键:

ALTER TABLE 表名 DROP FOREIGN KEY 外键名;

删除/更新行为

| 行为          | 说明                                                              |
| ----------- | --------------------------------------------------------------- |
| NO ACTION   | 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新(与RESTRICT一致)        |
| RESTRICT    | 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新(与NO ACTION一致)       |
| CASCADE     | 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则也删除/更新外键在子表中的记录              |
| SET NULL    | 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(要求该外键允许为null) |
| SET DEFAULT | 父表有变更时,子表将外键设为一个默认值(Innodb不支持)                                  |

更改删除/更新行为:

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名(主表字段名) ON UPDATE 行为 ON DELETE 行为;
posted @ 2024-09-09 15:31  test369  阅读(5)  评论(0编辑  收藏  举报