MySQL基础篇-约束
目录
1.约束概述
2.分类
3.测试user表的约束情况
主键约束
非空约束及唯一约束
检查约束
默认约束
4.外键约束
外键约束的语法
外键约束的删除/更新行为
小结
1.约束概述
MySQL约束(Constraints)是用于确保表中数据完整性和一致性的规则。它们定义了数据库表中数据的限制条件,以确保数据满足特定的要求。
2.分类
-
主键约束(Primary Key Constraint):主键是用于唯一标识表中每一行的列或列组合。主键列的值必须是唯一的,且不能为NULL。主键约束确保了表中的每一行都有一个唯一标识符。
-
唯一约束(Unique Constraint):唯一约束确保列或列组合中的值是唯一的,但允许NULL值。它用于防止在表中出现重复的数据。
-
外键约束(Foreign Key Constraint):外键用于建立表之间的关联关系。外键约束确保一个表中的值存在于另一个表的主键列中。这有助于维护表之间的引用完整性。
-
检查约束(Check Constraint):检查约束定义了列中允许的值的范围或条件。它可以用于强制数据的完整性,例如,确保年龄列中的值大于等于18。(版本要求是8.0.16之后)
-
默认约束(Default Constraint):默认约束定义了在插入新行时,如果未提供值,则将插入的默认值。这有助于确保表中的数据始终具有某些预定义的值。
-
非空约束(NOT NULL Constraint):非空约束确保列中的值不为空,即不能包含NULL值。
平常中的数据表,例如id 它是唯一标识,且不为空 ,并且一般情况下都是自己增长,对这些字段的限制进行一些约束,不满足条件的情况下是无法修改数据表中的数据的。
下面创建一个user表来测试
create table user(id int primary key auto_increment comment '主键',name varchar(10) not null unique comment '昵称',age int check ( age > 0 and age <= 120 ) comment '年龄',status char(1) default '1' comment '状态',gender char(1) comment '性别'
) comment '用户表'
这个案例几乎把上面的六种约束都用到了,id有主键约束,其中的auto_increment是自增设置,name有非空约束和唯一约束,age则是检查约束,status则是默认约束。
3.测试user表的约束情况
主键约束
插入数据
insert into user(name, age, status, gender) values ('zs',19,'1','男'), ('ls',13,'0','女')
执行完后可以看到并没有插入id,但是因为我们使用的主键约束及自增处理,所以id会自增且会保持唯一性。
进一步验证唯一性可以执行下面的sql,先删除id为2的数据,在插入一个元素
delete from user where id = 2;
insert into user(name, age, status, gender) values ('ww',29,'1','男');
可以看到执行完后id=2的数据虽然呗删除了,但是因为它存在过,为了保持唯一性id会自增到3。
非空约束及唯一约束
按照上面的流程,我们再次插入name为‘ww’的元素,sql执行时会报错
insert into user(name, age, status, gender) values ('ww',29,'1','男');
执行这样的sql,name字段为null或者不插入
insert into user(name, age, status, gender) values (null,29,'1','男');
insert into user( age, status, gender) values (20,'1','男')
会出现这样的错误
检查约束
插入这样一条数据,age明显大于了我们要求的范围,此时也会出现对应的错误
insert into user(name, age, status, gender) values ('ll',121,'1','男');
默认约束
执行这样的sql语句,不插入status,则会填入默认规定的 ‘1’
insert into user(name, age, gender) values ('pp',11,'男');
4.外键约束
通过前面的分类大概就能知道了外键约束的作用,也就是通过某个字段将一张表与另外一张表关联起来,比如像下面的这种情况。
建表sql:
create table dept(id int auto_increment primary key,name varchar(40) not null comment '部门名称'
) comment '部门表';
insert into dept (name) values ('研发部'),('市场部'),('财务部');create table spm(id int auto_increment primary key ,name varchar(50) not null ,age int,job varchar(40) comment '职位',dept_id int comment '部门ID'
) comment '员工表';insert into spm ( name, age, job, dept_id) values ('zs',20,'前端',1),('ls',30,'销售',2);
此时这里有一张员工表
以及一张部门表
员工表中的dept_id关联的是部门表,如果此时我们修改其中的数据,因为没有采用外键约束,他们相互之间是不受影响的,这只是一种理论上的约束关联,要想让他们真正的关联起来就要使用到外键约束。
外键约束的语法
建表时给予外键约束
create table 表名(字段名 数据类型,...[constraint] [外键名称] foreign key(外键字段名) references 主表(主表列名)
)
因为我在之前就已经建好了表,现在只能采用第二种方法
alter table spm add constraint fk_spm_dept_id foreign key (dept_id) references dept(id);
现在我们想删除部门表中的数据就会出现报错
此时已经建立了联系,为了保证数据的完整性,不能随意的删除数据了,此时就达到了 完整性,一致性的目的了。
删除关联
alter table spm drop foreign key fk_spm_dept_id;
外键约束的删除/更新行为
外键约束的删除/更新行为主要目的还是为了维护数据的完整性和一致性,并确保表之间的关系得以维护。
常见的有以下这些
-
NO ACTION:当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT一致)。
-
SET NULL:当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(这就要求该外键允许取null)’。
-
SET DEFAULT:父表有变更时,子表将外键列设置成一个默认的值(Innodb不支持)
-
RESTRICT:当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与NO ACTION一致)
-
CASCADE:当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录。
案例:
建立cascade连接
alter table spm add constraint fk_spm_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade ;
此时建立连接后,只要修改父表中的数据则与之建立联系的表也会跟着修改,正如上面描述的那样
小结
-
约束的作用:
- 约束是一种用于确保数据库中数据的完整性和一致性的重要工具。
- 它们定义了数据库表中数据的规则和限制,以防止无效或不一致的数据进入数据库。
-
主要约束类型:
- 主键约束(PRIMARY KEY):用于唯一标识表中的每一行,确保每个值都是唯一的,同时不允许NULL值。
- 唯一约束(UNIQUE):确保列中的值是唯一的,但允许NULL值。
- 外键约束(FOREIGN KEY):用于建立表之间的关联关系,确保引用完整性,防止无效引用和维护数据一致性。
- 检查约束(CHECK):定义列中允许的值的范围或条件,确保数据满足特定规则。
-
主键和唯一约束的区别:
- 主键是一种用于唯一标识行的特殊唯一约束,同时不允许NULL值。
- 唯一约束确保列中的值是唯一的,但允许一个NULL值。
-
外键约束的作用:
- 外键约束用于建立表之间的关系,确保引用的数据在被引用表中存在。
- 它可以配置为级联更新或级联删除,以维护数据的一致性。
- 外键约束有助于防止孤立数据和维护数据的完整性。
-
检查约束的作用:
- 检查约束定义了列中允许的值的范围或条件。
- 它用于确保数据满足特定规则,例如日期范围、数值范围等。
-
约束的创建和管理:
- 约束可以在表的创建时定义,也可以在后续使用
ALTER TABLE
语句进行修改或删除。 - 可以为列级别或表级别的约束,具体取决于约束的作用范围。
- 约束可以在表的创建时定义,也可以在后续使用
在MySQL中,正确使用约束可以帮助您设计更加健壮和可靠的数据库,确保数据的完整性和一致性,同时提供了数据关系的强大功能。深入了解和熟练应用这些约束对于数据库开发和管理非常重要。
相关文章:

MySQL基础篇-约束
目录 1.约束概述 2.分类 3.测试user表的约束情况 主键约束 非空约束及唯一约束 检查约束 默认约束 4.外键约束 外键约束的语法 外键约束的删除/更新行为 小结 1.约束概述 MySQL约束(Constraints)是用于确保表中数据完整性和一致性的规则。它们定…...

系统工程知识体系(SEBoK)
介绍 《系统工程知识体系》(SEBoK)是以一种理念设计的,即如果工程师有一个实时更新、实用的指南,他们就能做出更优秀的工作。如果你以前没有使用过这个资源,也没有关系;因为已经有一个完整的指南供你参考&…...
Spring DI (Dependency Injection)
What Is DI? 当一个类需要依赖另一个对象,把另一个对象实例化之后注入给这个对象的过程我们称之为DI # Create an object dependency in traditional programming public class Store {private Item item;public Store() {item new ItemImpl1(); } }# Using …...

Spring Boot : ORM 框架 JPA 与连接池 Hikari
数据库方面我们选用 Mysql , Spring Boot 提供了直接使用 JDBC 的方式连接数据库,毕竟使用 JDBC 并不是很方便,需要我们自己写更多的代码才能使用,一般而言在 Spring Boot 中我们常用的 ORM 框架有 JPA 和 Mybaties ,本…...

Wireshark抓包分析ICMP协议
「作者主页」:士别三日wyx 「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」:对网络安全感兴趣的小伙伴可以关注专栏《网络安全入门到精通》 分析目的:分析ICMP协议的数据格式、报文…...

C++——安装环境、工具
一、进入官网下载 Visual Studio 下载地址:https://visualstudio.microsoft.com/zh-hans/ 二、安装 三、安装完后如果出现window SDK 下载失败,可自行下载,如果没有请跳过这一步 Window SDK 官方地址:https://developer.microsoft…...
征稿啦!第 18 届「中国 Linux 内核开发者大会」重磅启动
第十八届中国 Linux 内核开发者大会(CLK )如期而至。CLK 以“自由、协作、创新”为理念,以开源技术的推广和普及为使命,旨在促进 Linux 内核开发爱好者相互交流,共同进步。 经过组委会公开征集承办单位和各意向承办单…...
JDBC8.0+
首先创建工程,导入jar包 1.注册驱动 //注册驱动//利用反射,较为灵活Class.forName("com.mysql.cj.jdbc.Driver");/**问题:会注册俩次驱动* 解决方案:只触发静态代码块* 触发静态代码块:* 类加载机制&…...
聊聊常见的IO模型 BIO/NIO/AIO 、DIO、多路复用等IO模型
文章目录 一、前言1. 什么是IO模型2. 为什么需要IO模型 二、常见的IO模型1. 同步阻塞IO(Blocking IO,BIO)2. 同步非阻塞IO(Non-blocking IO,NIO)3. 异步非阻塞IO(Asynchronous IO,AI…...

Linux- 网络编程初探
原始套接字(Raw Socket) 原始套接字(Raw Socket)是一种提供较低级别网络访问的套接字。通过使用原始套接字,应用程序可以直接发送或接收网络层如IP的数据包,或者传输层如TCP、UDP的段,而无需通…...

AVLoadingIndicatorView - 一个很好的Android加载动画集合
官网 GitHub - HarlonWang/AVLoadingIndicatorView: DEPRECATED 项目简介 AVLoadingIndicatorView is a collection of nice loading animations for Android. You can also find iOS version of this here. Now AVLoadingIndicatorView was updated version to 2.X , If …...

我想设计一套游戏的奖励系统,有什么值得注意的?
游戏上: 游戏成就系统的价值 游戏中的成就可以延长游戏时间,让玩家不仅仅是将游戏通关,而是必须完成游戏内所有挑战及发现秘密,这些成就可以与游戏本身的目标一致,也可以独立于游戏的主要或次要目标之外,…...

精通git,没用过git cherry-pick?
前言 git cherry-pick是git中非常有用的一个命令,cherry是樱桃的意思,cherry-pick就是挑樱桃,从一堆樱桃中挑选自己喜欢的樱桃,在git中就是多次commit中挑选一个或者几个commit出来,也可以理解为把特定的commit复制到…...
QT5|C++|通过创建子线程方式实现进度条更新
背景: 一开始是通过在主线程中写一个for循环,每次加1后睡眠1s进行进度条更新。但这样写的结果是 --> 无法动态显示进度条进度。后通过上一篇文章 [ QT5|C|通过信号槽机制实现进度条更新 ] 中的写信号槽机制实现。实现后 考虑了下有没有其他方式实现&a…...
基于mediasoup的webrtc server,性能压测时发现带宽利用率偏低(40%)
基于mediasoup的webrtc server,进行性能压测时发现,在1gbps的网络条件下,带宽利用率在40%(400Mbps)时,就会出现过高丢包率的(packet loss > 10%)的情况。这个结果是合理的吗?如果不合理,要如何提升性能&…...
Ubuntu Redis开机自启动服务
1. 建立service文件 sudo vim /etc/systemd/system/redis-server.service2. redis service文件 [Unit] DescriptionAdvanced key-value store Afternetwork.target Documentationhttp://redis.io/documentation, man:redis-server(1)[Service] Typenotify ExecStart/usr/bin/…...

Stm32_标准库_呼吸灯_按键控制
Stm32按键和输出差不多 PA1为LED供给正电,PB5放置按键,按键一端接PB5,另一端接负极 void Key_Init(void){RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE); //APB2总线连接着GPIOBGPIO_InitStructur.GPIO_Mode GPIO_Mode_IPU;GPIO_InitStructur.…...

MySQL作业:索引、视图、存储、函数
学生表:Student (Sno, Sname, Sex , Sage, Sdept) 学号,姓名,性别,年龄,所在系 Sno为主键 课程表:Course (Cno, Cname,) 课程号,课程名 Cno为主键 学生选课表:SC (Sno, Cno, Score) …...
漫谈:C语言 C++ 所有编程语言 =和==的麻烦
这次不只是C语言很麻拐,是所有编程语言都很麻拐了。 赋值和比较是编程语言最基本的操作之二,C和所有类C语言都使用“”和“”来分别表示赋值和比较。 数学上等号“”是个单一的概念,含义是“相等”,左右两边是等价的,很…...
十五、异常(1)
本章概要 异常概念基本异常 异常参数 异常捕获 try 语句块异常处理程序终止与恢复 Java 的基本理念是“结构不佳的代码不能运行”。 改进的错误恢复机制是提高代码健壮性的最强有力的方式。错误恢复在我们所编写的每一个程序中都是基本的要素,但是在 Java 中它显得…...

SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...

通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...

HDFS分布式存储 zookeeper
hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架,允许使用简单的变成模型跨计算机对大型集群进行分布式处理(1.海量的数据存储 2.海量数据的计算)Hadoop核心组件 hdfs(分布式文件存储系统)&a…...

基于 TAPD 进行项目管理
起因 自己写了个小工具,仓库用的Github。之前在用markdown进行需求管理,现在随着功能的增加,感觉有点难以管理了,所以用TAPD这个工具进行需求、Bug管理。 操作流程 注册 TAPD,需要提供一个企业名新建一个项目&#…...
return this;返回的是谁
一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请,不同级别的经理有不同的审批权限: // 抽象处理者:审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...

基于SpringBoot在线拍卖系统的设计和实现
摘 要 随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统,主要的模块包括管理员;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...
MinIO Docker 部署:仅开放一个端口
MinIO Docker 部署:仅开放一个端口 在实际的服务器部署中,出于安全和管理的考虑,我们可能只能开放一个端口。MinIO 是一个高性能的对象存储服务,支持 Docker 部署,但默认情况下它需要两个端口:一个是 API 端口(用于存储和访问数据),另一个是控制台端口(用于管理界面…...

协议转换利器,profinet转ethercat网关的两大派系,各有千秋
随着工业以太网的发展,其高效、便捷、协议开放、易于冗余等诸多优点,被越来越多的工业现场所采用。西门子SIMATIC S7-1200/1500系列PLC集成有Profinet接口,具有实时性、开放性,使用TCP/IP和IT标准,符合基于工业以太网的…...