MySQL四 | 约束

目录

约束的种类

添加外键约束

在创建表时添加外键

创建表之后添加外键

更新/删除外键约束的规则

删除外键

更新指令


约束是作用于表中字段上的规则,用于限制存储在表中的数据,可以保证数据库中数据的正确,有效性和完整性。

约束的种类

  1. 非空约束 NOT NULL 指示某列不能存储NULL值
  2. 唯一约束 UNIQUE 指示某列的每行必须有唯一的值
  3. 主键约束 PRIMARY KEYNOT NULL 与 UNIQUE的结合,确保某列(或两个列多个列的结合)有唯一标识,有助于更快速的找到表中的一个特点的记录
  4. 默认约束 DEFAULT 指定没有给列赋值时的默认值
  5. 检查约束 CHECK 保证列中的值符合指定的条件
  6. 外键约束 FOREIGN KEY 保证一个表中的数据匹配另一个表中的值的参考完整性

添加外键约束

在创建表时添加外键

sql 复制代码
create table 表名(

字段名 数据类型,

...

[constraint] [外键名称] foreign key(外键字段名) references 主表(主表列名);

);

创建表之后添加外键

sql 复制代码
alter table 表名 add constraint 外键名称 foreign key (外键字段名称) references 主表(主表列名);

更新/删除外键约束的规则

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

删除外键

sql 复制代码
alter table 表名 drop foreign key 外键名称;

更新指令

sql 复制代码
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;

更新为第三个规则

sql 复制代码
alter table emp add constraint fk_emp_dept_id foreign kry (dept_id) references dept(id) on update cascade on dalete cascade;
相关推荐
陈卓41018 分钟前
MySQL-主从复制&分库分表
android·mysql·adb
IT项目管理1 小时前
达梦数据库DMHS介绍及安装部署
linux·数据库
你都会上树?1 小时前
MySQL MVCC 详解
数据库·mysql
大春儿的试验田1 小时前
高并发收藏功能设计:Redis异步同步与定时补偿机制详解
java·数据库·redis·学习·缓存
Ein hübscher Kerl.2 小时前
虚拟机上安装 MariaDB 及依赖包
数据库·mariadb
长征coder2 小时前
AWS MySQL 读写分离配置指南
mysql·云计算·aws
醇醛酸醚酮酯2 小时前
Qt项目锻炼——TODO清单(二)
开发语言·数据库·qt
ladymorgana2 小时前
【docker】修改 MySQL 密码后 Navicat 仍能用原密码连接
mysql·adb·docker
PanZonghui2 小时前
Centos项目部署之安装数据库MySQL8
linux·后端·mysql
GreatSQL社区3 小时前
用systemd管理GreatSQL服务详解
数据库·mysql·greatsql