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、外键。
  • 是一个列。
  • 用来维护两张表的关系。

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

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

相关文章

msys2更换国内源(多个文件(不是3个文件的版本!))

msys2更换国内源 起因排查答案如下mirrorlist.mingw64mirrorlist.ucrt64mirrorlist.mingw32mirrorlist.mingwmirrorlist.clang64mirrorlist.clang32mirrorlist.msys 不想看经过的直接跳到答案 起因 查了很多个教程大部分都是【打开MSYS2软件内的\etc\pacman.d\ 中3个文件&…

使用 MMDetection 实现 Pascal VOC 数据集的目标检测项目练习(二) ubuntu的下载安装

首先&#xff0c;Linux系统是人工智能和深度学习首选系统。原因如下: 开放性和自由度&#xff1a;Linux 是一个开源操作系统&#xff0c;允许开发者自由修改和分发代码。这在开发和研究阶段非常有用&#xff0c;因为开发者可以轻松地访问和修改底层代码。社区支持&#xff1a;…

TCP Analysis Flags 之 TCP Keep-Alive

前言 默认情况下&#xff0c;Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态&#xff0c;并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时&#xff0c;会对每个 TCP 数据包进行一次分析&#xff0c;数据包按照它们在数据包列表中出现的顺序进行处理。可…

关于数学建模的一些介绍

为了更好了解世界&#xff0c;我们可以通过数学来描述许多特定的现象&#xff0c;而数学模型就是现实世界的理想化&#xff0c;不过它永远不能完全精确地表示现实世界。 在这篇文章中&#xff0c;我将介绍一些数学建模的基本概念以及相应的基础知识&#xff0c;而关于更具体的…

CSRA的LINUX操作系统24年11月2日下午上课笔记

压缩和解压缩&#xff1a;zip 、gzip、bz、xz # zip 压缩 # 压缩文件夹 # 解压缩 # unzip -v 查看压缩包中的内容 # bzip2 dir1/* :将dir1中的所有文件压缩 # gzip # 压缩文件夹 # 解压缩 tar 归档命令&#xff1a; # 创建tar包 tar -c*f # 释放tar包 tar -xf[c] # c …

Java JUC(四) 自定义线程池实现与原理分析

目录 一. 阻塞队列 BlockingQue 二. 拒绝策略 RejectPolicy 三. 线程池 ThreadPool 四. 模拟运行 在 Java基础&#xff08;二&#xff09; 多线程编程 中&#xff0c;我们简单介绍了线程池 ThreadPoolExecutor 的核心概念与基本使用。在本文中&#xff0c;我们将基于前面学…

施耐德M310PLC通讯之ModbusTCP(一)

这是另一个专题----施耐德国产化PLC(M310)的通讯篇 本节是ModbusTcp通讯 测试对象: M310plc与M241PLC 通讯协议: ModbusTcp 主站:M310PLC 从站:M241PLC 1.M310端: 1.1 新建工程(M310采用EcoStruxure Motion Expert 软件) 新建工程,这里不区分PLC型号的,只要是M310即…

电能表预付费系统-标准传输规范(STS)(30)

6.5.3.2 CONTROLBlock construction The 1 6 digit CONTROLBlock is constructed from the data elements in the APDU as defined in Table 36 and Table 37.The most significant digit is in position 1 5 and the least significant digit in position 0. APDU中的数据元素…

Jmeter基础篇(19)JSR223预处理器

前言 JSR223预处理器是Apache JMeter中的一个组件&#xff0c;它允许用户使用任何支持Java Scripting API (JSR 223) 的脚本语言来执行预处理任务。这个功能非常强大&#xff0c;因为它让测试人员能够利用如Groovy、JavaScript&#xff08;Nashorn引擎&#xff09;、BeanShell…

Python基于TensorFlow实现双向循环神经网络GRU加注意力机制分类模型(BiGRU-Attention分类算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后关注获取。 1.项目背景 随着深度学习技术的发展&#xff0c;循环神经网络&#xff08;RNN&#xff09;及其变种如门控循环…

echart实现地图数据可视化

文章目录 [TOC](文章目录) 前言一、基本地图展示2.数据可视化 总结 前言 最近工作安排使用echarts来制作图形报表&#xff0c;记录一下我的步骤&#xff0c;需求呈现一个地图&#xff0c;地图显示标签&#xff0c;根据业务指标值给地图不同省市填充不同颜色&#xff0c;鼠标放…

数学真题总结

举反例 看清正负号 对应的特征值一致 不用裁开计算行列式要注意符号&#xff01;&#xff01;&#xff01; 根据值的大小确定正负 没有思路就构建tanx求极值要考虑端点线性方程&#xff1a;求通解归并x几何意义 整体思想 u e^x y都设计好了&#xff0c;曲线是f(x,y) 0,直接把…

ES跟Kafka集成

配合流程 1. Kafka作为分布式流处理平台&#xff0c;能够实时收集和处理不同数据源的数据流&#xff1b; 2. 通过Kafka Connect或者Logstash等中间件&#xff0c;可以将Kafka中的数据流实时推送到Elasticsearch中&#xff1b; 3. Elasticsearch接收到数据后&#xff0c;会根据…

价格文本对齐

记录一下工作里常遇到的一些简单问题&#xff1a; 需求是一个购买按钮上同时展示原价和现价&#xff1a; 1.原价现价文本格式不同 2.原价切需要加打折红线&#xff0c;不方便用富文本一个文本处理。 3.需要对两条文本适配父节点的宽度&#xff0c;不能超出按钮 以下是实现代…

c++:vector模拟实现

一、vector成员变量 库里实现用的就是这三个成员变量&#xff0c;咱们实现跟库里一样&#xff0c; namespace myvector {template<class T>class vector{public://vecttor的迭代器是原生指针typedef T* iterator;typedef const T* const_iterator; private:iterator _sta…

【热门主题】000023 计算机视觉:算法与应用的深度探索

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 【热…

国产服务器平台离线部署k8s和kubesphere(含离线部署新方式)

"信创&#xff1a;鲲鹏麒麟&#xff0c;ARM64架构&#xff0c;实现K8s和Kubesphere的离线部署&#xff0c;全新方式助力企业高效运维。" 本文将深入探讨如何借助鲲鹏CPU(arm64)和操作系统Kylin V10 SP2/SP3,通过KubeKey制作KubeSphere与Kubernetes的离线安装包&#…

「C/C++」C/C++ 之 指针详解

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「C/C」C/C程序设计&#x1f4da;全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「PK」Parasoli…

CSS--导航栏案例

利用CSS制作北大官网导航栏 详细代码如下&#xff1a; <!DOCTYPE html> <html><head><meta charset"utf-8"><title></title><style>*{margin: 0;padding: 0;}#menu{background-color: darkred;width: 100%;height: 50px…

【语义分割|代码解析】CMTFNet-2: CNN and Multiscale Transformer Fusion Network 用于遥感图像分割!

【语义分割|代码解析】CMTFNet-2: CNN and Multiscale Transformer Fusion Network 用于遥感图像分割&#xff01; 【语义分割|代码解析】CMTFNet-2: CNN and Multiscale Transformer Fusion Network 用于遥感图像分割&#xff01; 文章目录 【语义分割|代码解析】CMTFNet-2: …