当前位置: 首页 > news >正文

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的完整性约束(详细介绍))

目录 一、完整性约束。 &#xff08;1&#xff09;概念与目的。 <1>概念。 <2>目的。 &#xff08;2&#xff09;各个约束的详细&#xff08;表格&#xff09; &#xff08;3&#xff09;各个约束的简要总结。 <1>主键约束。 <2>唯一约束。 <3>非…...

复原IP地址

分割字符串的姐妹题 题目&#xff1a;93. 复原 IP 地址 - 力扣&#xff08;LeetCode&#xff09; 题解&#xff1a;代码随想录 代码&#xff1a; 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 并不禁止析构函数吐出异常&#xff0c;…...

以「JIMUMETA元宇宙体验馆」为例,探讨有哪些元宇宙场景?

让我们以「JIMUMETA元宇宙体验馆」为例&#xff0c;深入探讨元宇宙场景中提供的产品与服务。该体验馆由视创云展精心打造&#xff0c;集成了企业主展馆、元宇宙虚拟活动分会场、品牌展示分会场、线上论坛会场以及会议室接待会客等多重功能&#xff0c;旨在全方位满足企业发布会…...

RHCE的练习(8)

动态网站 lnmp&#xff08;LAMP&#xff09; 解析index.php界面 &#xff08;1&#xff09;预配&#xff0c;确保服务能够被访问 systemctl stop firewalld setenforce 0 &#xff08;2&#xff09;安装nginx服务 mount /dev/sr0 /mnt cat /etc/yum.repos.d/base.repo dnf …...

yocto是如何收集recipes,如何加入现有的bb文件

yocto通常是如何收集recipes: 在Yocto中&#xff0c;通过以下方式收集recipes&#xff1a; 层&#xff08;Layers&#xff09; Yocto项目使用层来组织recipes。层是包含配置文件、recipes和其他相关文件的目录结构。每个层有自己的目录&#xff0c;其中 recipes-* 目录用于存…...

[运维] 服务器本地网络可用性检查脚本

引言 在日常活动中&#xff0c;我遇到过一个令人头疼的问题。测试使用的远程终端在第二天继续使用时可能就发生无法与外网通信的情况&#xff0c;往往连上终端后在拉取资源时才能发现。这导致每次使用前都需要手动检查网络状况&#xff0c;增加了不必要的麻烦。为了简化这一过…...

MYSQL-显示信息关于服务器插件语法(二十五)

13.7.5.25 SHOW PLUGINS 语句 SHOW PLUGINSSHOW PLUGINS 显示信息 关于服务器插件。 SHOW PLUGINS 输出示例&#xff1a; mysql> SHOW PLUGINS\G *************************** 1. row ***************************Name: binlogStatus: ACTIVEType: STORAGE ENGINE Librar…...

【线下培训】龙信受邀参加开封市公安局举办的电子数据取证培训班

文章关键词&#xff1a;电子数据取证、手机取证、云取证、国产化取证 为了提升开封市公安机关在互联网电子数据取证分析方面的专业能力&#xff0c;龙信为开封市公安机关量身打造了一场高质量的电子数据取证分析技能培训课程。 本次培训课程不仅涵盖了电子数据取证的基础理论、…...

软件测试工程师面试整理 —— 编程与自动化!

在软件测试领域&#xff0c;编程与自动化是提升测试效率、覆盖率和可靠性的关键因素。掌握编程技术和自动化测试框架&#xff0c;能够帮助测试人员有效地执行大量重复性测试任务&#xff0c;并迅速反馈软件的质量状况。以下是编程与自动化在测试中的主要应用及相关技术介绍&…...

【鸿蒙新闻】10月29日警用鸿蒙开发者大会在北京胜利召开,开启智慧应用新时代!

10月29日&#xff0c;在公安部科技信息化局、公安部装备财务局指导下&#xff0c;由公安部第一研究所主办&#xff0c;鼎桥通信技术有限公司、OpenHarmony生态委员会及公共安全专委会协办的警用鸿蒙开发者大会在北京胜利召开。会议以“拥抱警鸿创新生态 开启智慧应用新时代”为…...

java.io.IOException: Too many open files

java.io.IOException: Too many open files 前言&#xff1a; 项目最近报 java.io.IOException: Too many open files 问题&#xff0c;大概意思是&#xff1a;意味着你的应用程序尝试打开的文件描述符数量超过了系统允许的最大数量&#xff0c;在linux中每个进程打开的文件描…...

ElementUI el-form表单多层数组的校验

问题描述 提示&#xff1a;这里描述项目中遇到的问题&#xff1a; ElementUI el-form表单多层数组的校验 页面效果&#xff1a; 数据结构&#xff1a; addform: {code: ,type: ,value: ,state: 1,remark: ,fieldList: [{fieldCode: ,resolverEntities: [{resolverType: , re…...

常见的向量范数、矩阵范数和对偶范数-对偶范数详细证明过程

文章目录 对偶范数一般定义&#xff1a; p p p-范数和 q q q-范数的对偶性特例 1&#xff1a;无穷范数和 1 范数的对偶性特例 2&#xff1a;2 范数的对偶是自身特例 3&#xff1a;有限范数与 0 范数的对偶关系&#xff08;稀疏性&#xff09;特例 4&#xff1a;核范数&#xff…...

Android 滴滴面经

Android 滴滴面经 文章目录 Android 滴滴面经一面二面三面 一面 Activity的启动的四种模式&#xff0c;四种启动模式的应用场景&#xff0c;单例模式的启动场景&#xff0c;我回答的是闹钟&#xff0c;反问&#xff1a;在单例模式下闹钟运行时点击back键&#xff0c;是回退到闹…...

angular登录按钮输入框监听

说明&#xff1a;angular实现简单的登录页面&#xff0c;监听输入框的值&#xff0c;打印出来&#xff0c;按钮监听&#xff0c;打印数据 效果图: 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 以上版本】

文章目录 &#x1f4d5;课程总结&#x1f4d5;安装 Unity 编辑器与打包模块&#x1f4d5;导入 OpenXR&#x1f4d5;导入 XR Interaction Toolkit&#x1f4d5;打包发布 获取完整课程以及答疑&#xff0c;工程文件下载&#xff1a; https://www.spatialxr.tech/ 视频试看链接&a…...

element-plus校验单个form对象合法性

在 Vue 中&#xff0c;循环生成的表单列表&#xff0c;并且每个表单中包含多个对象&#xff0c;使用 v-for 来创建这些表单&#xff0c;并且使用动态 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命令打包和拆包 重点是…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

前端开发面试题总结-JavaScript篇(一)

文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包&#xff08;Closure&#xff09;&#xff1f;闭包有什么应用场景和潜在问题&#xff1f;2.解释 JavaScript 的作用域链&#xff08;Scope Chain&#xff09; 二、原型与继承3.原型链是什么&#xff1f;如何实现继承&a…...

今日科技热点速览

&#x1f525; 今日科技热点速览 &#x1f3ae; 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售&#xff0c;主打更强图形性能与沉浸式体验&#xff0c;支持多模态交互&#xff0c;受到全球玩家热捧 。 &#x1f916; 人工智能持续突破 DeepSeek-R1&…...

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题

【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要&#xff1a; 近期&#xff0c;在使用较新版本的OpenSSH客户端连接老旧SSH服务器时&#xff0c;会遇到 "no matching key exchange method found"​, "n…...

GitFlow 工作模式(详解)

今天再学项目的过程中遇到使用gitflow模式管理代码&#xff0c;因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存&#xff0c;无论是github还是gittee&#xff0c;都是一种基于git去保存代码的形式&#xff0c;这样保存代码…...

【JVM面试篇】高频八股汇总——类加载和类加载器

目录 1. 讲一下类加载过程&#xff1f; 2. Java创建对象的过程&#xff1f; 3. 对象的生命周期&#xff1f; 4. 类加载器有哪些&#xff1f; 5. 双亲委派模型的作用&#xff08;好处&#xff09;&#xff1f; 6. 讲一下类的加载和双亲委派原则&#xff1f; 7. 双亲委派模…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制

目录 节点的功能承载层&#xff08;GATT/Adv&#xff09;局限性&#xff1a; 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能&#xff0c;如 Configuration …...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下&#xff0c;推客小程序系统凭借其裂变传播、精准营销等特性&#xff0c;成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径&#xff0c;助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

系统掌握PyTorch:图解张量、Autograd、DataLoader、nn.Module与实战模型

本文较长&#xff0c;建议点赞收藏&#xff0c;以免遗失。更多AI大模型应用开发学习视频及资料&#xff0c;尽在聚客AI学院。 本文通过代码驱动的方式&#xff0c;系统讲解PyTorch核心概念和实战技巧&#xff0c;涵盖张量操作、自动微分、数据加载、模型构建和训练全流程&#…...