MySQL 6:数据库约束

1.概念与类型

概念: 数据库约束是指对数据库表中的数据施加的规则或条件 ,用于确保数据的准确性和可靠性 。这些约束可以是基于数据类型、值范围、唯一性、非空等 规则,以确保数据的正确性和相容性。


约束类型

2.NOT NULL 非空约束

定义表时某列不允许为NULL时,可以为列添加非空约束

对于明确不会为空的列,建议主动添加该约束,这不仅保障 数据完整性,也能优化查询效率。

举例:创建一个学生表,约束学生名的列不能为NULL。

• 为所有列添加非空约束

• 由于name列有非空约束,插入NULL值时报错。

• 正常值可以成功插入

sql 复制代码
drop table if exists student;

create table student(
 id bigint,
 name varchar(20) not null
);

NULL列为NO表示值不允许为NULL ,YES表示值可以为NULL。

• 查看表结构,name列Null 属性值NO


3.DEFALUT 默认值约束

DEFAULT 约束用于向列中插入默认值 ,如果没有为列设置值 ,那么会将默认值设置到该列

举例:为年龄 列加入默认

重构 学生表,新增年龄列,年龄列加入默认约束。

• 插入一条记录,不指定年龄的值时列使用了默认值 (若没有设置默认约束 时会为NULL )。

sql 复制代码
drop table student;

create table student (
 id bigint,
 name varchar(20) not null,
 age int default 18
);

• 查看表结构age****列Default 属性值 18


4.UNIQUE 唯一约束

指定了唯一约束的列该列的值在所有记录中不能重复 ,比如⼀个人的身份证号学生的学号等。

对于明确是唯一的列,建议主动添加该约束,这不仅保障 数据完整性,也能优化查询效率。

注意: 唯一约束只确保非 NULL 值的唯一性 ,通常允许存在多个 NULL 值

举例:设置学号唯一

重构 学生表,新增学号列并设置唯一约束。

• 插入重复的学号时报错唯一 约束生效

sql 复制代码
drop table student;

create table student (
 id bigint,
 name varchar(20) not null,
 age int default 18,
 sno varchar(10) unique
);

• 查看表结构sno列Key 属性值UNI, 表示该学号列成功添加唯一约束


5.PRIMARY KEY 主键约束

5.1 定义



5.2 示例

举例:将学生表的id 列 设为主键

重构 学生表,为id 添加主键约束。

• 查看表结构, id列Key 属性值PRI ,表示 id 已被成功 设为主键

sql 复制代码
drop table student;

create table student (
 id bigint primary key,
 name varchar(20) 
);

• 当Id列的重复时 会发生主键冲突



通常把主键列 设置为自动增长 ,让数据库维护主键值一个表只能有一个自增列

重构 学生表,将学生表的id 列 设为自增主键。

• 插入数据时,设置主键列的值为NULL 或 不设置主键列的值(推荐)主键列的值都会自动生成。

sql 复制代码
drop table student;

create table student (
 id bigint primary key auto_increment, 
 name varchar(20),
 age int
);

• 查看表结构,id列Extra 属性值auto_increment 表示自增


• 如果某条记录写入失败生成的主键值 将会作废

由于 id 重复 ,产生了唯一冲突 ,导致插入失败 ,ID为 3主键值作废

修改 id 后成功插入数据 ,查询后发现新记录 id 列的值为4


• 主键值可以不 连续,手动指定⼀个值,下一次自增从主键最大值开始。

当然也可以手动指定中间的值 ,但是下一次自增仍从主键最大值开始。


主键或唯一键冲突时更新操作


替换 ,如果存在冲突替换不存在冲突插入


一个表只能有一个主键


一个主键可以包含多个列

复合主键,由多个列共同组成的主键 ,主键是否冲突多个列的组成进行判定。


6.FOREIGN KEY 外键约束


举例:

• 创建班级表(主表),并初始化数据

• 重构学生表(从表) ,加入外键约束

sql 复制代码
create table class (
 id bigint primary key auto_increment,
 name varchar(20) not null
);
sql 复制代码
# 创建外键约束
class_id bigint,
foreign key (class_id) references class(id) 

• 查看表结构,class_id列Key 属性值MUL ,表示该列已成功添加外键约束



• 正常向从表插入 数据,班级编号在主表中存在,插入成功。


• 插入班级Id为NULL 的记录,可以成功 ,表示当前学生还没有分配班级



删除主表 前,请先处理依赖关系 ,可选择删除从表解除所有外键约束清空从表数据

解除所有外键约束

清除从表数据


7.CHECK 约束



相关推荐
冬奇Lab8 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐10 小时前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence19 小时前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横21 小时前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神21 小时前
三、用户与权限管理
数据库·mysql
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
ApacheSeaTunnel2 天前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化