Mysql_11 约束

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 学习自黑马网课。

用于限制字段规则。

约束 说明
not null 非空
unique 唯一,不能重复
primary key 主键,非空且唯一
default 默认值
check 保证字段值都满足某个条件
foreign key 连接两张表之间的数据,保证数据的一致性和完整性
# 创建表时:
create table(
    id int primary key comment 'id';
    age int check (age>=0 && age<=100) comment '年龄',
    gender char(1) default 'm' comment '性别'
);
# 修改表时:主键,unique,外键用 add,其他用 modify

alter table add primary key(列名);

alter  table table_name modify 列名 数据类型  not null;# 如果是 null,就是取消非空约束

# 外键需要先创建一个字段,然后给这个字段添加外键。原外键的字段和新的要添加外键的字段数据类型要一样。
alter table 子表名 add constraint 外键名 foreign key (要添加外键的字段) references 父表名(父表字段);

alter table 表名 drop foreign key 外键名;

之后子表引用了父表,父表被引用的记录就不能随便删除了。子表也不能随便写外键的值,必须要在父表中存在才可以引用。

外键删除更新行为 说明
no action/restrict 父表要删除/更新的记录如果在子表中存在关联记录,则不删除/更新
cascade 父表要删除/更新的记录如果在子表中存在关联记录,则子表中的记录也删除/更新
set null 父表要删除/更新的记录如果在子表中存在关联记录,则子表中的记录对应字段设为空值(前提:该字段可以为 null)
set default 父表要删除/更新的记录如果在子表中存在关联记录,则子表中的记录也删除/更新对应字段设为默认值
alter table 子表名 add constraint 外键名 foreign key (要添加外键的字段) references 父表名(父表字段) on update cascade on delete cascade;
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
3月前
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
4天前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
13 1
|
1月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
31 0
在 MySQL 中使用约束
|
3月前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
27 1
|
3月前
|
数据采集 关系型数据库 MySQL
MySQL数据库基础第三篇(约束)
MySQL数据库基础第三篇(约束)
|
3月前
|
关系型数据库 MySQL
MYSQL约束(自增长,以及非空约束)
MYSQL约束(自增长,以及非空约束)
|
3月前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】4.6-约束
【MySQL技术内幕】4.6-约束
31 1
|
3月前
|
SQL 关系型数据库 MySQL
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
39 5
|
3月前
|
SQL 关系型数据库 MySQL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL

热门文章

最新文章