MySQL约束

·概述

1、概念:

约束是作用于表中字段上的规则,用于限制存储在表中的数据。

2、目的:

保证数据库中数据的正确、有效性和完整性。

3、分类:

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

注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。

·约束演示

根据下图的条件,添加约束

create table user(

id int primary key auto_increment comment '主键', -- auto_increment是自增

name varchar(10) not null unique comment '姓名',

age int check (age > 0 && age <= 120) comment '年龄',

status char(1) default '1' comment '状态',

gender char(1) comment '性别'

)comment '用户表';

·外键约束

外键是用来让两张表之间建立连接,从而保证数据的一致性和完整性。

只是在逻辑上关联,但是在数据库上并没有联系

添加外键:

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

删除外键:

alter table emp drop foreign key fk_emp_dept_id;

相关推荐
_千思_12 分钟前
【小白说】数据库系统概念 4
数据库
专注&突破31 分钟前
DeepAgents 的 Backend详解
数据库
星火开发设计39 分钟前
序列式容器:list 双向链表的特性与用法
开发语言·前端·数据结构·数据库·c++·链表·list
Zzz 小生44 分钟前
LangChain Messages:消息使用完全指南
数据库·windows·microsoft
寂寞旅行9 小时前
向量数据库Milvus的使用
数据库·milvus
闻哥10 小时前
Redis事务详解
java·数据库·spring boot·redis·缓存·面试
道亦无名10 小时前
aiPbMgrSendAck
java·网络·数据库
面向对象World13 小时前
正点原子Mini Linux 4.3寸800x480触摸屏gt115x驱动
linux·服务器·数据库
dinga1985102613 小时前
mysql之联合索引
数据库·mysql
微风中的麦穗14 小时前
【SQL Server 2019】企业级数据库系统—数据库SQL Server 2019保姆级详细图文下载安装完全指南
大数据·数据库·sqlserver·云计算·个人开发·运维必备·sqlserver2019