【关系模型】关系完整性约束

按照上面的框架我们已经讲了关系数据结构还有关系操作,今天来补充这一章的关系完整性约束

关系完整性约束

完整性约束

完整性约束可以保证数据的一致性和元组的唯一性

实体完整性约束

比如在学生表中,每一个元组都应该是唯一并且元组之间是可以区分的,通常通过对主键进行约束。比如主键下的值不能是空值,并且不能有重复的情况。即非空性和唯一性。

违反非空性:

用户ID (UserID)

用户名 (Username)

邮箱 (Email)

101

Alice

alice@example.com

102

Bob

bob@example.com

NULL

Eve

eve@example.com

103

Charlie

charlie@example.com

下面这个则违反了唯一性:

用户ID (UserID)

用户名 (Username)

邮箱 (Email)

101

Alice

alice@example.com

102

Bob

bob@example.com

101

Charlie

charlie@example.com

上面两个关系的主键都是用户ID(UserID)

若主键不单单是一个属性列,而是多个属性列组成的,即复合键,它也同时要满足非空性和唯一性。

例如下面这个就违反了非空性

学生ID (StudentID)

课程ID (CourseID)

成绩 (Grade)

1

CS101

A

2

MATH202

B+

NULL

CS101

B-

3

NULL

C+

4

CS101

A-

违反唯一性:

学生ID (StudentID)

课程ID (CourseID)

成绩 (Grade)

1

CS101

A

1

MATH202

B+

2

CS101

B

3

CS101

A-

1

CS101

C+

上面两个关系的复合键都是学生ID和课程ID。

在修改数据(包含插入、修改、删除)时若是违反了上述规则,数据库是不会运行该数据操作的,它会选择拒绝,因为在设计数据库时会设置好实体完整性约束,事实上都是为了每一个元组都唯一且彼此之间可区分。

参照完整性约束

这个约束是指主键和外键的对应关系不能出错,比如在在选课表中的外键是学生ID,而学生ID在学生表中是主键,主键和外键要“相等”,“一模一样”。

学生ID (StudentID)

姓名 (Name)

1

张三

2

李四

3

王五

学生ID (StudentID)

课程ID (CourseID)

1

CS101

2

MATH202

4

CS101

3

PHYS303

比如这个就明显违反了该约束,因为在选课表中出现了学生表没有的学生ID。而且在进行删除操作时,禁止删除主键(被引用),进行插入操作时,主键(被引用)先更新,即不能直接对外键值进行操作,要确保外键值是有效的,就必须是被引用的主键(也叫参照)先进行关系操作。

用户定义完整性约束

之前在说域这个概念时就有提到关系中的每个属性都存在一个取值集合即域,比如学生的年龄是大于等于0的。其实这个就是用户定义完整性约束。主要是体现在数据库的应用场景下,再比如学生表中每一个学生都必须要有性别和年龄信息,Sname 和Sage都不能取空值。

其他约束

非空约束

指某一属性下的值不能是空值,比如特定对Sage属性进行非空约束,那么就不能插入一个年龄为空的学生信息。

唯一约束

也是指对某一属性进行唯一约束,即不能取重复值,但是可以取空值,并且可以对多个属性进行约束,比完整性约束作用范围更大。

自增长约束

某一属性列的值必须满足自增,比如用户ID,学生号(2021210223->2021210224)

默认值约束

比如某一属性列的值默认是空值(NULL)或者0,也可以是其他默认值。

检查约束

某一属性必须满足某一取值范围,比如Sage必须大于等于零。

关系模型就暂告一段落了,接下来学习第三章——数据库设计

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【游戏模组】极品飞车12无间风云冬季mod,冬天版本的无间风云你体验过吗

各位好,今天小编给大家带来一款新的高清重置魔改MOD,本次高清重置的游戏叫《极品飞车12无间风云》。 《极品飞车12:无间风云》是由Black Box游戏制作室开发的竞速类游戏,于2008年11月18日在北美首发、2008年11月21日在欧洲先后推…

Java基础:面向对象编程7

1 Java 不可变对象 1.1 什么是不可变类 定义:一个类的对象在通过构造方法创建后,其状态(成员变量值)不会再被改变,这样的类称为不可变(immutable)类。特点: 所有成员变量的赋值仅在…

生成 Excel 表列名称

Excel 大家都用过,它的列名是用字母编号的,A 表示第一列,B 表示第二列,AA 表示第27列,AB 表示第28列等等。 现给定一个数字,如何得到列名称呢。比如输入28,输出 AB。 一开始以为就是一个简单的…

2017年计算机网络408真题解析

第一题: 解析:OSI体系结构数据包的逐层封装 应用层发送的400B数据称为应用层协议数据单元,也就是题目所说的PDU, 表示层将应用层发过来的PDU添加一个20B的首部,封装称为表示层PDU,并将其交付给会话层&#…

接口测试(一)基础

一、http请求格式 请求&#xff1a;从客户端到服务端的请求消息 请求消息格式 请求行&#xff1a;请求方法、请求URL、HTTP协议及版本 URL的一般形式为<协议>://<主机>:<端口>/<路径>/<文件名>请求头部空一行请求体 请求方法 请求方法get请求…

HCIP——以太网交换安全(四)DHCP Snooping

目录 一、DHCP Snooping的知识点 二、DHCP Snooping实验拓扑 三、总结 一、DHCP Snooping的知识点 1.1、DHCP snooping 概述&#xff1a; ①DHCP Snooping使能DHCP的一种安全特性&#xff0c;用于保证DHCP客户端从合法的DHCP服务端获取IP地址。DHCP服务器记录DHCP客户端IP…

pycharm 找不到conda环境

参考&#xff1a;新版Pycharm解决Conda executable is not found-CSDN博客

[C++刷题] 基础小知识点(1) 乘方函数pow()

乘方 pow() 该函数在math.h头文件中 例如: 求圆的面积公式 s3.14*pow(r,2); 例题: #include<iostream> using namespace std; #include<math.h>) int main() {int h;int r;cin >> h >> r;double v h * 3.14 * pow(r, 2);int ret 0;if (v > 200…

slam系列4:nerf和3dgs

常用的3维表示法&#xff1a; NeRF属于是density的模型&#xff0c;模型的参数如下&#xff1a; 传统的 3D 模型表示方法&#xff0c;如 离散的Mesh 和点云&#xff0c;以及连续的 Nerf&#xff0c;通常面临着一个主要问题&#xff1a;随机采样过程中产生的噪声&#xff0c;这…

P5430 7.68T U.2 NVME SBFPF2BU076T001 Solidigm固态硬盘

SBFPF2BU076T001 Solidigm P5430 7.68T U.2 NVME企业级固态硬盘 Solidigm针对企业应用推出D5-P5430固态硬盘&#xff0c;针对主流和读取密集型应用程序进行了优化&#xff0c;面向大量企业工作它采用PCIe Gen 4总线与QLC类型NAND颗粒&#xff0c;提供大量的存储密度并降低总拥…

《云计算网络技术与应用》实训6-1:配置KVM虚拟机使用NAT网络

任务1、计算节点基础环境准备 1. 使用VMware安装CentOS 7虚拟机&#xff0c;安装时记得开启CPU虚拟化&#xff0c;命名为“KVMC6”。 2. &#xff08;网卡配置和之前的一样&#xff0c;都用100网段&#xff09;网关设置为192.168.100.1&#xff0c;地址段为192.168.100.10-25…

数据分析:R语言计算XGBoost二分类模型的SHAP值

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍SHAP用途计算方法:应用加载R包导入数据建模平均SHAP值计算单个样本的每个特征的SHAP值蜜蜂图依赖图单个样本的SHAP解释(Force Plot)其他方法计算SHAP值单个个体预测结果系统信息…

轻松掌握:如何查找家中WiFi的IP地址

在如今数字化生活的时代&#xff0c;WiFi已成为我们日常生活中不可或缺的一部分。无论是上网冲浪、在线学习、还是远程办公&#xff0c;稳定的WiFi连接都显得尤为重要。然而&#xff0c;有时我们可能需要了解家中WiFi的IP地址&#xff0c;以便进行网络设置、故障排查或进行其他…

基于springboot留守儿童爱心网站

作者&#xff1a;计算机学长阿伟 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、ElementUI等&#xff0c;“文末源码”。 系统展示 【2024最新】基于JavaSpringBootVueMySQL的&#xff0c;前后端分离。 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;…

爬虫之数据提取

HTML数据提取 这一片文章, 我们一起学习如何利用HTML标签来提取数据。 我们打开二手房网站: 我们打开开发者工具, 找到请求: 这次我们找的请求, 和以前的不一样了, 所以这里面带大家找一找, 以前我们找的请求都是json格式的响应数据, 那今天由于我们要学习如何提取html数据, …

Jenkins实践(三):分包编译部署到Maven私仓

本文主要是针对springboot多模块项目&#xff0c;参数化构建、分包部署到maven私仓的记录。本文以上篇文章为基础进行记录。 系列文章&#xff1a; Jenkins入门&#xff08;一&#xff09;&#xff1a;从搭建到部署第一个Springboot项目(踩坑记录)_ub24.04安装jenkins-CSDN博…

LinkedList和链表(上)

1. 顺序表ArrayList的缺点和优点 优点: 1> 在给定下标进行查找的时候,时间复杂度是O(1) 缺点: 1> 插入数据必须移动其他数据,最坏情况下,插入到0位置,时间复杂度为O(N) 2> 删除数据也需要移动数据,最坏情况下,就是删除0位置.时间复杂度为O(N) 3> 扩容之后(1.5倍扩容…

《深度学习》OpenCV 物体跟踪 原理及案例解析

目录 一、物体跟踪 1、什么是物体跟踪 2、步骤 1&#xff09;选择跟踪算法 2&#xff09;初始化跟踪器 3&#xff09;在每个视频帧上执行跟踪 4&#xff09;可选的重新初始化 3、原理 二、案例实现 1、完整代码 1&#xff09;使用方式 2&#xff09;运行结果 2、关…

麒麟桌面版v10 SP1以docker方式安装达梦数据库

安装docker 0.切换root用户&#xff08;可以不切换&#xff0c;但要注意权限问题&#xff0c;我是用root&#xff09; ymym-pc:~/桌面$ whoami ym ymym-pc:~/桌面$ sudo -i rootym-pc:~# whoami root rootym-pc:~# 1.查看系统版本 [rootlocalhost opt]# cat /etc/os-release…

java类和对象(上)

前言&#xff1a; 不知道大家有没有将java方法的使用熟记入心呢&#xff1f;如果没有的话&#xff0c;可以打开博主的上一篇博文阅读哦&#xff0c;在这里谢谢大家一路的陪伴。也希望我的内容能够帮到你更快的掌握java语言的学习。接下来我们要讲的是java类和对象。让我们整理…