【MySQL学习笔记007】约束

1、概述

(1)概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。

(2)目的:保证数据库中数据的正确、有效性和完整性。

(3)分类

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

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

2、约束演示

(1)案例

|--------|--------|-------------|---------------|-----------------------------|
| 字段名 | 字段含义 | 字段类型 | 约束条件 | 约束关键字 |
| id | ID唯一标识 | int | 主键,并且自动增长 | primary key, auto_increment |
| name | 姓名 | varchar(10) | 不为空,并且唯一 | Not null, unique |
| age | 年龄 | int | 大于0,并且小于等120 | check |
| status | 状态 | char(1) | 如果没有指定该值,默认为1 | default |
| gender | 性别 | char(1) | 无 | |

(2)实现

sql 复制代码
create table user(
    id int primary key auto_increment comment '主键',
    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 '用户表';

-- 插入数据
-- 主键原则,id自动延长
insert into user(name, age, status, gender) values ('Tom1', 19, '1', '男'), ('Tom2', 25, '0', '男');

insert into user(name, age, status, gender) values ('Tom3', 32, '3', '女');

-- name not null
insert into user(name, age, status, gender) values (null, 32, '3', '女');
# [23000][1048] Column 'name' cannot be null
-- name unique
insert into user(name, age, status, gender) values ('Tom3', 32, '3', '女');
# [23000][1062] Duplicate entry 'Tom3' for key 'user.name'

-- age check >0 <=120
insert into user(name, age, status, gender) values ('Tom4', 40, '3', '女');
# 此时主键id变为5,这是因为刚刚的操作已经像数据库申请了id=4的主键,因此此时id为5
insert into user(name, age, status, gender) values ('Tom5', -1, '3', '女');
# [HY000][3819] Check constraint 'user_chk_1' is violated.
insert into user(name, age, status, gender) values ('Tom5', 121, '3', '女');
# [HY000][3819] Check constraint 'user_chk_1' is violated.

-- status default '1'
insert into user(name, age, gender) values ('Tom5', 120, '女');
# 成功插入

3、外键约束

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

注意: 目前上述的两张表,在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的

(1)添加外键

语法

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

(2) 删除外键

语法

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

(3)删除/更新行为

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

语法

sql 复制代码
alter table 表名 add constraint 外键名称 foreign key (外键字段) references 主表名(主表字段名) on update cascade on delete cascade
相关推荐
并不会1 小时前
常见 CSS 选择器用法
前端·css·学习·html·前端开发·css选择器
龙鸣丿1 小时前
Linux基础学习笔记
linux·笔记·学习
C吴新科3 小时前
MySQL入门操作详解
mysql
Nu11PointerException3 小时前
JAVA笔记 | ResponseBodyEmitter等异步流式接口快速学习
笔记·学习
亦枫Leonlew5 小时前
三维测量与建模笔记 - 3.3 张正友标定法
笔记·相机标定·三维重建·张正友标定法
考试宝5 小时前
国家宠物美容师职业技能等级评价(高级)理论考试题
经验分享·笔记·职场和发展·学习方法·业界资讯·宠物
Ai 编码助手6 小时前
MySQL中distinct与group by之间的性能进行比较
数据库·mysql
白云如幻6 小时前
MySQL排序查询
数据库·mysql
苹果醋36 小时前
Java8->Java19的初步探索
java·运维·spring boot·mysql·nginx
黑叶白树7 小时前
简单的签到程序 python笔记
笔记·python