mysql上课总结(5)(MySQL的完整性约束(详细介绍))
目录
一、完整性约束。
(1)概念与目的。
<1>概念。
<2>目的。
(2)各个约束的详细(表格)
(3)各个约束的简要总结。
<1>主键约束。
<2>唯一约束。
<3>非空约束。
<4>默认值约束。
<5>外键约束。
<6>检查约束。
(4)设置约束的操作演示。
<1>两种添加约束方式。
<2>创建表时,同时添加约束。
1、创建学生表。
2、在列声明后面直接声明主键(跟着书写)。
编辑
3、另起一行声明主键。创建班级表。
<3>表已经创建好了,以修改表的方式来添加约束。
<4>主键约束设计。
<5>自动递增约束。
<6>外键约束。
(5)表与表之间的关系。
<1>三种关系。
1、一对一。
2、一对多。(多对一)
3、多对多。
<2>简要的概述。
组合主键。(联合主键)
<3>外键与外键约束区别。
1、外键约束。
2、外键。
一、完整性约束。
- MySQL的完整性约束用于确保数据库中的数据准确性和一致性。
- 这些约束通过定义规则来限制表中可以存储的数据类型和值。
(1)概念与目的。
<1>概念。
- 约束是作用于表中字段上的规则,用于限制存储在表中的数据。
<2>目的。
- 保证数据库中数据的正确、有效性和完整性。
(2)各个约束的详细(表格)
约束名称 描述 关键字 主键约束 1、主键是一行数据的唯一标识,要求非空且唯一。
2、唯一标识表中的每一行。
3、可以由一个或多个列组成(复合主键)。
PRIMARY KEY
(primary key)
唯一约束 1、保证该字段的所有数据都是唯一、不重复的。
2、确保一列或多列的值在表中是唯一的。
3、允许为空值,但多个空值不视为重复。
UNIQUE
(unique)
外键约束 1、用来让两张表的数据之间建立连接,保证数据的一致性和完整性。
2、确保一个表中的值在另一个表中存在(参照完整性)。
3、用于维护表之间的关系(例如,一对多、多对多)。FOREIGN KEY
(foreign key)
非空约束 1、限制该字段的数据不能为null 。
2、适用于所有数据类型。
NOT NULL
(not null)
默认(值)约束 1、保存数据时,如果未指定该字段的值,则采用默认值 DEFAULT
(default)
自动递增约束 1、通常与主键一起使用,自动生成唯一的数字序列。
2、通常用于主键列,确保每次插入新行时都有唯一的标识符。AUTO_INCREMENT
(auto_increment)
检查约束(8.0.16及更高版本支持) 1、保证字段值满足某一个条件。
2、check(age > 0)确保年龄列中的值是非负的。
CHECK
(check)
- 注意。约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。
(3)各个约束的简要总结。
<1>主键约束。
- 唯一且不为null(空)。
- 每一张表只能有一个主键约束!
- 如果一个表的其它字段想要设置唯一怎么办?用唯一约束!
<2>唯一约束。
- 只能保证唯一。但不能保证不为空。
- 每一张表可以有多个唯一约束!如:一张用户表的邮件、电话号码等等都需要唯一。
<3>非空约束。
- 不能为null。必须要赋值。
<4>默认值约束。
- 给列设置一个默认值。
- 如:给sex(性别)设置默认值'男',如果性别没有赋值,就是男。
<5>外键约束。
- 关于两张表的约束。
- 子表某列的数据来源于主表的某列数据。比如:有一张"学生表",其里面有一个班级id字段。那么这个班级id,在另外一张"班级表"中是存在的。
<6>检查约束。
- MySQL的高版本里才有。(8.0.16及更高版本支持)
- 限定值的范围。限制性别只能是男或女、年龄在18~50岁等等。
- 低版本不支持这个约束的使用。
(4)设置约束的操作演示。
<1>两种添加约束方式。
- 第一种。表已经创建好了。以修改表的方式添加约束。不过最好前提表里面没有数据,否则可能会因为一些数据冲突,导致加不进去。
- 第二种。在创建表时,一起将需要的约束添加好!也就是在数据库设计的时候就要考虑清楚。(推荐使用!)
<2>创建表时,同时添加约束。
1、创建学生表。
- 其中id (唯一不能为空, 主键约束),name(非空),sex(默认值 男),age,email(唯一)。
2、在列声明后面直接声明主键(跟着书写)。
create table tb_student(id int primary key, #主键约束name varchar(50) not null, #非空约束sex varchar(10) default '男', #默认值约束age int,email varchar(100) unique #唯一约束 );
- 张三没有赋值性别,系统自动使用默认值'男'。
- 其它数据插入时,没有任何冲突,所以添加成功!
- 主键约束。唯一且非空。"王五"学生添加失败!
唯一约束。不允许"王五"与"李四"邮箱一样!
修改后。
3、另起一行声明主键。创建班级表。
(一般默认约束与非空约束不能另起一行写!)
- 班级表: id(主键),cname 班级名称(非空),loc 教室位置(唯一)。
- 创建表。
- 其中主键、唯一约束另起一行书写声明。
create table tb_class(id int,cname varchar(100) not null,loc varchar(100),primary key(id),unique (loc) );
- 测试失败。(原因)
- 测试成功!
<3>表已经创建好了,以修改表的方式来添加约束。
- 如果表中的数据违反约束,则添加失败。
- 主键操作方式。
- 补充:一般批量插入数据的时候,表中选择没有添加约束。否则执行sql脚本、批量添加数据时就会一个个检查约束,查看数据是否符合约束,就会很慢!所以等添加完数据,再添加约束也是可以的。
<4>主键约束设计。
- 每张表都应该有一个主键。
- 主键加在非业务数据上列,主键不允许修改。
<5>自动递增约束。
- auto_increment:自增列只能有一个,加在主键,唯一键。
- 自增列。默认开始值: 1, 每次加1。
- 如果手动给自增列赋值,程序是否报错? 不报错 。
- id:100 则下一个自增列的值:101。
- 程序如下。具体测试大家可以自己试试!
create table tb_class(id int auto_increment,cname varchar(100) not null,loc varchar(100),primary key(id),unique (loc) );insert into tb_class values (100,'一年级三班','2栋304');insert into tb_class(cname,loc) values ('一年级四班','2栋305');
<6>外键约束。
- 其实就是为了防止数据的不完整性!(下次补充!!)
(5)表与表之间的关系。
<1>三种关系。
1、一对一。
2、一对多。(多对一)
3、多对多。
<2>简要的概述。
- 一对一。
- 例如(t_person)表和(t_card)表,即人和身份证。
- 这种情况需要找出主从关系,即谁是主表,谁是从表。
- 人可以没有身份证,但身份证必须要有人才行,所以人是主表,而身份证是从表。设计从表可以有两种方案。
在t_card表中添加外键列(相对t_user表),并且给外键添加唯一约束;
给t_card表的主键添加外键约束(相对t_user表),即t_card表的主键也是外键。
一对多(多对一)。
最为常见的就是一对多!
一对多和多对一,这是从哪个角度去看得出来的。
t_user和t_section的关系,从t_user来看就是一对多,而从t_section的角度来看就是多对一!这种情况都是在多方创建外键!
例如存在一张员工表(emp)与一张部门表(dept)。一个部门里有多个员工,但是一个员工只能对应一个部门。则部门是(一),而员工是(多)。那么外键应该设置在员工表(emp)中的部门id(dept_id),对应着部门表(dept)的主键(dept_id)。
多对多。
例如:t_stu和t_teacher表,即一个学生可以有多个老师,而一个老师也可以有多个学生。
这种情况通常需要创建中间表来处理多对多关系。
所以需要创建一张表(tb_stu_tea)表,给出两个外键,一个相对t_stu表的外键,另一个相对t_teacher表的外键。
组合主键。(联合主键)
为了防止存相同的值。
可以设置组合主键(联合主键)——>primary key(stu_id,tea_id)!!变成了需要两个字段的值——>两两相等才会违背主键唯一。
<3>外键与外键约束区别。
1、外键约束。
- 对外键的一种约束。
- 外键的值只能来源于主表主键值,唯一键值。
2、外键。
- 是一个列。
- 用来维护两张表的关系。
相关文章:
mysql上课总结(5)(MySQL的完整性约束(详细介绍))
目录 一、完整性约束。 (1)概念与目的。 <1>概念。 <2>目的。 (2)各个约束的详细(表格) (3)各个约束的简要总结。 <1>主键约束。 <2>唯一约束。 <3>非…...
复原IP地址
分割字符串的姐妹题 题目:93. 复原 IP 地址 - 力扣(LeetCode) 题解:代码随想录 代码: class Solution {List<String> resnew ArrayList<>();public List<String> restoreIpAddresses(String s) …...
Effective C++ 学习笔记二
Effective C 学习笔记二 文章目录 Effective C 学习笔记二别让异常逃离析构函数绝不在构造和析构的过程中调用virtual函数令operator 返回一个reference to *this在operator中处理"自我赋值"C四种转换 别让异常逃离析构函数 C 并不禁止析构函数吐出异常,…...
以「JIMUMETA元宇宙体验馆」为例,探讨有哪些元宇宙场景?
让我们以「JIMUMETA元宇宙体验馆」为例,深入探讨元宇宙场景中提供的产品与服务。该体验馆由视创云展精心打造,集成了企业主展馆、元宇宙虚拟活动分会场、品牌展示分会场、线上论坛会场以及会议室接待会客等多重功能,旨在全方位满足企业发布会…...
RHCE的练习(8)
动态网站 lnmp(LAMP) 解析index.php界面 (1)预配,确保服务能够被访问 systemctl stop firewalld setenforce 0 (2)安装nginx服务 mount /dev/sr0 /mnt cat /etc/yum.repos.d/base.repo dnf …...
yocto是如何收集recipes,如何加入现有的bb文件
yocto通常是如何收集recipes: 在Yocto中,通过以下方式收集recipes: 层(Layers) Yocto项目使用层来组织recipes。层是包含配置文件、recipes和其他相关文件的目录结构。每个层有自己的目录,其中 recipes-* 目录用于存…...
[运维] 服务器本地网络可用性检查脚本
引言 在日常活动中,我遇到过一个令人头疼的问题。测试使用的远程终端在第二天继续使用时可能就发生无法与外网通信的情况,往往连上终端后在拉取资源时才能发现。这导致每次使用前都需要手动检查网络状况,增加了不必要的麻烦。为了简化这一过…...
MYSQL-显示信息关于服务器插件语法(二十五)
13.7.5.25 SHOW PLUGINS 语句 SHOW PLUGINSSHOW PLUGINS 显示信息 关于服务器插件。 SHOW PLUGINS 输出示例: mysql> SHOW PLUGINS\G *************************** 1. row ***************************Name: binlogStatus: ACTIVEType: STORAGE ENGINE Librar…...
【线下培训】龙信受邀参加开封市公安局举办的电子数据取证培训班
文章关键词:电子数据取证、手机取证、云取证、国产化取证 为了提升开封市公安机关在互联网电子数据取证分析方面的专业能力,龙信为开封市公安机关量身打造了一场高质量的电子数据取证分析技能培训课程。 本次培训课程不仅涵盖了电子数据取证的基础理论、…...
软件测试工程师面试整理 —— 编程与自动化!
在软件测试领域,编程与自动化是提升测试效率、覆盖率和可靠性的关键因素。掌握编程技术和自动化测试框架,能够帮助测试人员有效地执行大量重复性测试任务,并迅速反馈软件的质量状况。以下是编程与自动化在测试中的主要应用及相关技术介绍&…...
【鸿蒙新闻】10月29日警用鸿蒙开发者大会在北京胜利召开,开启智慧应用新时代!
10月29日,在公安部科技信息化局、公安部装备财务局指导下,由公安部第一研究所主办,鼎桥通信技术有限公司、OpenHarmony生态委员会及公共安全专委会协办的警用鸿蒙开发者大会在北京胜利召开。会议以“拥抱警鸿创新生态 开启智慧应用新时代”为…...
java.io.IOException: Too many open files
java.io.IOException: Too many open files 前言: 项目最近报 java.io.IOException: Too many open files 问题,大概意思是:意味着你的应用程序尝试打开的文件描述符数量超过了系统允许的最大数量,在linux中每个进程打开的文件描…...
ElementUI el-form表单多层数组的校验
问题描述 提示:这里描述项目中遇到的问题: ElementUI el-form表单多层数组的校验 页面效果: 数据结构: addform: {code: ,type: ,value: ,state: 1,remark: ,fieldList: [{fieldCode: ,resolverEntities: [{resolverType: , re…...
常见的向量范数、矩阵范数和对偶范数-对偶范数详细证明过程
文章目录 对偶范数一般定义: p p p-范数和 q q q-范数的对偶性特例 1:无穷范数和 1 范数的对偶性特例 2:2 范数的对偶是自身特例 3:有限范数与 0 范数的对偶关系(稀疏性)特例 4:核范数ÿ…...
Android 滴滴面经
Android 滴滴面经 文章目录 Android 滴滴面经一面二面三面 一面 Activity的启动的四种模式,四种启动模式的应用场景,单例模式的启动场景,我回答的是闹钟,反问:在单例模式下闹钟运行时点击back键,是回退到闹…...
angular登录按钮输入框监听
说明:angular实现简单的登录页面,监听输入框的值,打印出来,按钮监听,打印数据 效果图: step1:E:\projectgood\ajnine\untitled4\src\app\app.config.ts import { ApplicationConfig, provideZoneChangeDetection } …...
硅谷甄选(10)用户管理
用户管理模块 9.1 静态搭建 主要是el-form、el-pagination <template><el-card style"height: 80px"><el-form :inline"true" class"form"><el-form-item label"用户名:"><el-input placeholder"请…...
Unity XR Interaction Toolkit 开发教程(2):导入 SDK【3.0 以上版本】
文章目录 📕课程总结📕安装 Unity 编辑器与打包模块📕导入 OpenXR📕导入 XR Interaction Toolkit📕打包发布 获取完整课程以及答疑,工程文件下载: https://www.spatialxr.tech/ 视频试看链接&a…...
element-plus校验单个form对象合法性
在 Vue 中,循环生成的表单列表,并且每个表单中包含多个对象,使用 v-for 来创建这些表单,并且使用动态 prop 路径来验证单个对象是否满足必填校验。 <template><el-form ref"formRef" :model"form" …...
Linux常见命令合集
目录 1.ls 列出指定目录下的文件和和文件夹 2.cd change directory 切换目录 3. cat 查看文件 4.more 分屏查看文件 5.tail从后往前查看指定文件 6.mkdir 创建目录 7.rm强制删除指定目录和文件 8.cp复制文件和目录 9.mv移动和重命名命令 10.tar命令打包和拆包 重点是…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...
Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...
iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘
美国西海岸的夏天,再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至,这不仅是开发者的盛宴,更是全球数亿苹果用户翘首以盼的科技春晚。今年,苹果依旧为我们带来了全家桶式的系统更新,包括 iOS 26、iPadOS 26…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
2.Vue编写一个app
1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...
12.找到字符串中所有字母异位词
🧠 题目解析 题目描述: 给定两个字符串 s 和 p,找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义: 若两个字符串包含的字符种类和出现次数完全相同,顺序无所谓,则互为…...
Java入门学习详细版(一)
大家好,Java 学习是一个系统学习的过程,核心原则就是“理论 实践 坚持”,并且需循序渐进,不可过于着急,本篇文章推出的这份详细入门学习资料将带大家从零基础开始,逐步掌握 Java 的核心概念和编程技能。 …...









