【MySQL】:约束全解析
🎥 屿小夏 :
个人主页
🔥个人专��� :
MySQL从入门到进阶
🌄 莫道桑榆晚,为霞尚满天!
文章目录
- 📑前言
- 一. 约束概述
- 二. 约束演示
- 三. 外键约束
- 3.1 介绍
- 3.2 语法
- 3.3 删除/更新行为
- 🌤️全篇总结
📑前言
数据库中的约束是确保数据完整性和准确性的重要手段。通过对数据表字段的约束设置,可以限制数据的取值范围、确保数据的唯一性以及建立表与表之间的关联关系。本文将深入介绍MySQL中的各种约束类型及其使用方法,包括非空约束、唯一约束、主键约束、默认约束、检查约束和外键约束,以及如何在创建表和修改表时添加约束,以及外键约束的相关知识。
一. 约束概述
概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。
目的:保证数据库中数据的正确、有效性和完整性。
分类:
约束 描述 关键字 非空约束 限制该字段的数据不能为null NOT NULL 唯一约束 保证该字段的所有数据都是唯一、不重复的 UNIQUE 主键约束 主键是一行数据的唯一标识,要求非空且唯一 PRIMARY KEY 默认约束 保存数据时,如果未指定该字段的值,则采用默认值 DEFAULT 检查约束(8.0.16版本 之后) 保证字段值满足某一个条件 CHECK 外键约束 用来让两张表的数据之间建立连接,保证数据的一致 性和完整性 FOREIGN KEY 注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束 。
二. 约束演示
如何在创建表、修改表的时候来指定约束呢,接下来我们就通过一个案例,来演示一下。
字段名 字段含 义 字段类型 约束条件 约束关键字 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) 无 对应的建表语句为:
CREATE TABLE tb_user( id int AUTO_INCREMENT PRIMARY KEY COMMENT 'ID唯一标识', name varchar(10) NOT NULL UNIQUE COMMENT '姓名' , age int check (age > 0 && age
The End