Mysql学习笔记之约束

news2025/1/5 8:30:52

1.简介

MySQL中的约束用于定义表中数据的规则,以确保数据的准确性和完整性。以保证数据表中数据的有效性、正确性和完整性。

2.约束分类

在mysql中约束分类如下:

约束说明关键字
主键约束每个表只能有一个主键;主键的值必须唯一,不能为NULL;主键用于唯一标识表中的每一行记录。PRIMARY KEY
唯一约束保证列中的所有值都是唯一的;可以有多个唯一约束;唯一约束列可以包含NULL值。UNIQUE
非空约束确保列中的值不能为NULL;可以有多个非空约束。NOT NULL
默认约束当没有为列指定值时,将使用默认值。DEFAULT
检查约束保证字段值满足某一个条件(早期版本不支持)。CHECK
外键约束用来让两张表的数据之间建立连接,保证数据的一致性和完整性;外键包含的列必须在另外一张表中作为主键或者唯一键存在。FOREIGN KEY

3.实例

在前面章节建立student表时,并没有进行约束限制,建表语句如下:

CREATE TABLE `students`  (
  `id` int COMMENT '学号',
  `name` varchar(255) COMMENT '姓名',
  `sex` varchar(2) COMMENT '性别',
  `age` int COMMENT '年龄'
)COMMENT '学生表';

在学生表中,每个学生的学号应该是唯一且不为空的,因此可以将id设为主键,而每个学生应该都有名字,因此name必须是非空的,但名字可以重复,所以不能设置为唯一,性别除了‘男’就是‘女’,可以设置检查约束来确保字段的正确性,同理年龄也应该是非空限制。
加上约束后的建表语句如下:

CREATE TABLE `students`  (
  `id` int PRIMARY KEY COMMENT '学号' ,
  `name` varchar(255) NOT NULL COMMENT '姓名',
  `sex` varchar(2) CHECK(sex IN('男','女')) COMMENT '性别',
  `age` int NOT NULL COMMENT '年龄'
) COMMENT '学生表';

接下来尝试插入一些错误的数据,看约束是否生效

  • 验证主键
    前面提到主键是不能为空,且唯一的,因此可以从两方面验证主键是否生效
-- 主键留空
INSERT INTO students (id,`name`,sex,age) VALUES(NULL,"张三","男",20);

提示id不能为空
在这里插入图片描述

-- 插入相同的主键
INSERT INTO students (id,`name`,sex,age) VALUES(1,"张三","男",20);
INSERT INTO students (id,`name`,sex,age) VALUES(1,"李四","男",20);

提示主键重复
在这里插入图片描述

  • 验证非空
    将名称或者年龄任意字段留空
-- 名称留空
INSERT INTO students (id,`name`,sex,age) VALUES(2,NULL,"男",20);

在这里插入图片描述
注意
NULL和空字符串不等 NOT NULL 不能限制空字符串,如果需要限制空字符串需要使用检查约束(CHECK)进行限制

  • 验证检查约束
    对性别字段插入除(男,女)外的别的字符
INSERT INTO students (id,`name`,sex,age) VALUES(2,"李四","你",20);

检查不通过
在这里插入图片描述

4.外键

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

  • 添加外键
CREATE TABLE 表名(
字段名 数据类型,
...
[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) 删除/更新行为
);
-- 或者
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名) 删除/更新行为;
  • 删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

4.1 删除/更新行为

添加了外键之后,再删除父表数据时产生的约束行为,我们就称为删除/更新行为。主要有以下几种:

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

4.2 实例

先准备两张表
1.班级表(class)
在这里插入图片描述
2.学生表(students)
在这里插入图片描述

  1. NO ACTION(RESTRICT)
    首先将学生表中classid设置为外键,管理class表的id字段(使用默认删除/更新行为)
ALTER TABLE students  ADD CONSTRAINT fk_classIs FOREIGN KEY (classid) REFERENCES class (id);

删除id为1的班级,提示错误,存在外键引用不能删除
在这里插入图片描述
2. CASCADE

ALTER TABLE students  ADD CONSTRAINT fk_classIs FOREIGN KEY (classid) REFERENCES class (id) on update cascade on delete cascade ;

原始数据
在这里插入图片描述
将id为3的班级设置为id为4
在这里插入图片描述
在这里插入图片描述
3. SET NULL

ALTER TABLE students  ADD CONSTRAINT fk_classIs FOREIGN KEY (classid) REFERENCES class (id) on update SET NULL on delete SET NULL;

删除id为4的班级信息

DELETE FROM class WHERE id = 4;

在这里插入图片描述

4.3 拓展

从上述删除/更新行为可以看出,外键的存在会导致数据表在插入、删除、更新数据时,都会先验证该记录是否存在外键,因此会带来额外的操作从而影响性能。所以外键的使用需要根据实际场景慎重考虑。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2269536.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LabVIEW 实现自动对焦的开发

自动对焦(Autofocus, AF)技术是通过分析图像或传感器信号,动态调整焦点位置以实现清晰成像或高精度定位的过程。在LabVIEW中,可以通过集成信号采集、数据处理、控制算法和硬件接口模块,实现多种自动对焦方法&#xff0…

2024年第52周ETF周报

ETF 第52 周 ( 2024-12-23 至 2024-12-29 )周报 核心观点 ETF 业绩表现 股票型ETF周度收益率中位数为1.0731%宽基ETF中,科创创业50涨跌幅中位数为1.5625%,跌幅最小。按板块划分,金融涨跌幅中位数为1.9334%&#xff…

[Qt] 万字详解Qt入门~ Qt Creator | 对象树 | 控件布局

目录 1. Qt Creator 概览 2. 使用 Qt Creator 新建项目 3. 认识 Qt Creator 界面 4. Qt Hello World 程序 1. 使用 “按钮” 实现 2. 使用 “标签” 实现 3. 使用 “编辑框” 实现 5. 项目文件解析 1. 命名空间声明与作用 2. class Widget : public QWidget 6. Qt 编…

远程命令执行之基本介绍

一.远程命令执行漏洞 1.命令执行 命令执行是指计算机程序接受用户输入的命令,并按照命令的要求执行相应的操作。命令可以执行各种操作,例如读取文件、创建文件、修改文件、运行程序、删除文件等。 命令执行通常是通过一个命令行界面或终端窗口进行的。在…

【数据结构-单调队列】力扣2762. 不间断子数组

给你一个下标从 0 开始的整数数组 nums 。nums 的一个子数组如果满足以下条件&#xff0c;那么它是 不间断 的&#xff1a; i&#xff0c;i 1 &#xff0c;…&#xff0c;j 表示子数组中的下标。对于所有满足 i < i1, i2 < j 的下标对&#xff0c;都有 0 < |nums[i1…

扩充vmware磁盘大小以及分区

扩充vmware磁盘大小以及分区 扩充vmware磁盘大小 分区 目前使用vmware版本为17.5.2 gparted fdisk cxqubuntu:~$ sudo fdisk -l Disk /dev/loop0: 219 MiB, 229638144 bytes, 448512 sectors Units: sectors of 1 * 512 512 bytes Sector size (logical/physical): 512 …

【Python图像处理】进阶实战续篇(七)

在上一篇文章中&#xff0c;我们探讨了Python在图像处理中的几个前沿技术&#xff0c;包括语义分割和视频帧间插值。本篇将继续深化这些话题&#xff0c;并进一步拓展到其他相关的高级技术应用中&#xff0c;以便为读者提供更为详尽的知识体系。 12. 深度学习在语义分割中的应…

TIOBE 指数 12 月排行榜公布,VB.Net排行第九

IT之家 12 月 10 日消息&#xff0c;TIOBE 编程社区指数是一个衡量编程语言受欢迎程度的指标&#xff0c;评判的依据来自世界范围内的工程师、课程、供应商及搜索引擎&#xff0c;今天 TIOBE 官网公布了 2024 年 12 月的编程语言排行榜&#xff0c;IT之家整理如下&#xff1a; …

从零开始开发纯血鸿蒙应用之UI封装

从零开始开发纯血鸿蒙应用 一、题引二、UI 组成三、UI 封装原则四、实现 lib_comps1、封装 UI 样式1.1、attributeModifier 属性1.2、自定义AttributeModifier<T>类 2、封装 UI 组件 五、总结 一、题引 在开始正文前&#xff0c;为了大家能够从本篇博文中&#xff0c;汲…

ChatBI来啦!NBAI 正式上线 NL2SQL 功能

NebulaAI 现已正式上线 NL2SQL 功能&#xff0c;免费开放使用&#xff01; 什么是 NL2SQL&#xff1f;NL2SQL 即通过自然语言交互&#xff0c;用户可以轻松查询、分析和管理数据库中的数据&#xff08;ChatBI&#xff09;&#xff0c;从此摆脱传统复杂的数据库操作。 欢迎免费…

UE5材质节点Frac/Fmod

Frac取小数 Fmod取余数 转场效果 TimeMultiplyFrac很常用 Timesin / Timecos 制作闪烁效果

二叉树的三种遍历方式以及示例图

二叉树的三种基本遍历方式是前序遍历&#xff08;Pre-order Traversal&#xff09;、中序遍历&#xff08;In-order Traversal&#xff09;和后序遍历&#xff08;Post-order Traversal&#xff09;。这三种遍历方式各有特点&#xff0c;适用于不同的场景。下面是每种遍历方式的…

数据表中列的完整性约束概述

文章目录 一、完整性约束概述二、设置表字段的主键约束三、设置表字段的外键约束四、设置表字段的非空约束五、设置表字段唯一约束六、设置表字段值自动增加七、设置表字段的默认值八、调整列的完整性约束 一、完整性约束概述 完整性约束条件是对字段进行限制&#xff0c;要求…

如何解决Eigen和CUDA版本不匹配引起的错误math_functions.hpp: No such file or directory

Apollo9针对RTX40的docker环境里的Eigen库版本是3.3.4&#xff0c;CUDA是11.8: 编译我们自己封装模型的某些component代码时没问题&#xff0c;编译一个封装occ模型的component代码时始终报错: In file included from /usr/include/eigen3/Eigen/Geometry:11:0, …

【非关系型数据库Redis 】 入门

Redis入门 一、非关系型数据库概述 &#xff08;一&#xff09;概念 非关系型数据库&#xff08;NoSQL&#xff0c;Not Only SQL&#xff09;是相对于传统的关系型数据库而言的一种数据存储管理系统。它摒弃了关系型数据库中严格的表结构、SQL 语言操作以及复杂的事务等特性…

0基础跟德姆(dom)一起学AI 自然语言处理10-LSTM模型

1 LSTM介绍 LSTM&#xff08;Long Short-Term Memory&#xff09;也称长短时记忆结构, 它是传统RNN的变体, 与经典RNN相比能够有效捕捉长序列之间的语义关联, 缓解梯度消失或爆炸现象. 同时LSTM的结构更复杂, 它的核心结构可以分为四个部分去解析: 遗忘门输入门细胞状态输出门…

Ribbon源码分析

一、Spring定制化RestTemplate&#xff0c;预留出RestTemplate定制化扩展点 org.springframework.cloud.client.loadbalancer.LoadBalancerAutoConfiguration 二、Ribbon定义RestTemplate Ribbon扩展点功能 org.springframework.cloud.netflix.ribbon.RibbonAutoConfiguratio…

【C++】智能指针详解(实现)

在本篇博客中&#xff0c;作者将会带领你理解并自己手动实现简单的智能指针&#xff0c;以加深对智能指针的理解。 一.什么是智能指针&#xff0c;为什么需要智能指针 智能指针是一种基于RAII思想实现的一种资源托管方式&#xff0c;至于什么是RAII&#xff0c;后面会讲到。 对…

【微服务】【Sentinel】认识Sentinel

文章目录 1. 雪崩问题2. 解决方案3. 服务保护技术对比4. 安装 Sentinel4.1 启动控制台4.2 客户端接入控制台 参考资料: 1. 雪崩问题 微服务调用链路中的某个服务故障&#xff0c;引起整个链路中的所有微服务都不可用&#xff0c;这就是雪崩。动图演示&#xff1a; 在微服务系统…

macos 支持外接高分辩率显示器开源控制软件

macos 支持外接高分辩率显示器开源控制软件 软件&#xff08;app应用&#xff09;名&#xff1a;BetterDisplay 官方地址&#xff1a; https://github.com/waydabber/BetterDisplay