数据库关系运算理论:关系数据操作与关系完整性概念解析

news2024/11/23 15:53:41

 
✨✨ 欢迎大家来访Srlua的博文(づ ̄3 ̄)づ╭
~✨✨

🌟🌟 欢迎各位亲爱的读者,感谢你们抽出宝贵的时间来阅读我的文章。

我是Srlua小谢,在这里我会分享我的知识和经验。🎥

希望在这里,我们能一起探索IT世界的奥妙,提升我们的技能。🔮

记得先点赞👍后阅读哦~ 👏👏

📘📚 所属专栏:数据库

欢迎访问我的主页:Srlua小谢 获取更多信息和资源。✨✨🌙🌙

目录

关系数据操作

关系的基本操作

关系操作的特点

关系数据语言

关系的完整性

完整性约束的分类

实体完整性

参照完整性

1.关系间的引用

2.外码

3.参照完整性规则

用户定义完整性


关系数据操作

关系的基本操作

关系模型中常用的关系操作包括查询操作插入删除修改操作两大部分。

关系的查询表达能力很强,是关系操作中最主要的部分。

查询操作可以分为:选择(select)、投影(Project)、除(Divide)、并(Union)、交(Intersection)、连接(Join)、差(Except)和笛卡儿积等

其中,选择、投影、并、差、笛卡儿积是五种基本操作其他操作是可以用基本操作来定义和导出的。

关系操作的特点

关系操作的特点是集合操作方式,即操作的对象和结果都是集合。

这种操作方式也称为一次一集合的方式,这里提到的“一个集”也可以理解为“一个关系”或“一个二维表”。

相应地,非关系数据模型的数据操作方式称为一次一记录的方式。


关系数据语言

(1)关系数据语言按照完成的功能可分为三类:

数据定义语言(DDL)、数据操纵语言(DML)和数据控制语言(DCL)。

(2)关系数据语言按照查询方式的不同可分为三类:

关系代数语言(如ISBL)、关系演算语言(如 APLHA)、具有关系代数与关系演算双重特点的语言(如 SQL)。


关系的完整性

完整性约束的分类

关系模型中有三类完整性约束:

实体完整性、参照完整性和用户定义的完整性。

(1)实体完整性和参照完整性是关系模型必须满足的完整性约束条件,被称作是关系的两个不变性,应该由关系数据库 DBMS 自动支持

(2)用户自定义的完整性是应用领域需要遵循的约束条件,体现了具体领域中的语义约束。


实体完整性

1.实体完整性规则

若属性 A 是基本关系 R 的主属性,则属性 A 不能取空值

2.实体完整性的必要性

(1)实体完整性规则是针对基本关系而言的。

一个基本表通常对应现实世界的一个实体集或一个多对多联系。

(2)现实世界中的实体和实体间的联系都是可区分的即它们具有某种唯一性标识

相应地,关系模型中以主码作为唯一性标识

(3)主码中的属性即主属性不能取空值。空值就是"不知道”或“无意义"的值主属性取空值,就说明存在某个不可标识的实体,即存在不可区分的实体,这与第(2)点相矛盾。(注意大写的 NULL 是空值)

3.实体完整性规则规定:基本关系的所有主属性都不能取空值

例如:学生实体中“学号”是主码,则“学号”不能取空值;“课程”是主码,则“课程号”不能取空值;学生选课关系——选修表(学号,课程号,成绩)中,"学号、课程号”是主码,则"学号、课程号”两个属性都不能取空值。

参照完整性

1.关系间的引用

现实世界中的实体之间往往存在着某种联系,在关系模型中实体及实体间的联系都是用关系来描述的。这样就自然存在着关系与关系间的引用

例如:学生、课程、学生与课程之间的多对多联系可以用如下三个关系表示:

        学生(学号,姓名,性别,年龄,院系)
        课程(课程号,课程名,学分)
        选修(学号,课程号,成绩)

这三个关系(或三张表)之间存在着属性的引用,即选修关系引用了学生关系的主码“学号”和课程关系的主码“课程号”。

2.外码

设F是基本关系 R的一个或一组属性,但不是关系R的码。如果F与基本关系S 的主码 KS 相对应,则称F是基本关系R的外码,基本关系 R称为参照关系(Referencing Relation),基本关系S称为被参照关系(Referenced Relation)或目标关系(Target Relation)。

在上例中,选修关系中的“学号”属性与学生关系的主码“学号”相对应;选修关系的“课程号”属性与课程关系的主码“课程号”相对应,因此“学号”和课程号”属性分别是选修关系的外码。这里学生关系和课程关系均为被参照关系选修关系为参照关系

3.参照完整性规则

        若属性(或属性组) F 是基本关系 R 的外码,它与基本关系 S 的主码 KS 相对应(基本关系 R 和S不一定是不同的关系),则对于R中每个元组在F上的值必须为:或取空值 ( F 的每个属性值均为空值);或等于S中某个元组的主码值。

结合实例,按照参照完整性规则“学号”和“课程号”属性也可以取两类值:空值或目标关系中已经存在的值。但由于“学号”和“课程号”是选修关系中的主属性,按照实体完整性规则,它们均不能取空值,并且选修关系中的“学号”和“课程号”属性实际上只能取相应被参照关系中已经存在的主码值。

1)学生关系中的专业号参照专业关系中的专业号,专业号的值可以是:

(1)空值——表示尚未给学生分配专业

(2)非空值——值必须取专业关系中专业号的值

2)学生关系中的班长与学号之间存在引用关系,班长的取值可以是:

(1)空值——表示该班级未选班长

(2)非空值——值必须取同一关系的学号

用户定义完整性

实体完整性与参照完整性是由系统自动支持的,这是关系模型所要求的。除此之外,不同的关系数据库系统根据其应用环境的不同往往需要一些特殊的约束条件,这就是用户定义的完整性约束件。

(1)用户定义完整性规则是针对某一具体关系数据库的约束条件反映某一具体应用所涉及的数据必须满足的语义要求。

(2)关系模型应提供定义和检验这类完整性的机制,以便用统一的系统的方法处理它们,而不要由应用程序承担这一功能。


(1)对属性的类型约束

年龄只能取整数,姓名的字符串长度最大为20。

(2)对属性的非空约束

学生的姓名不允许为空。

(3)对属性值的取值范围进行约束

学生成绩在 0一100 之间,在职职工的工资不低于1000 元等。

(4)对同一关系的不同元组进行约束

不允许出现两个不同的用户拥有相同的账号昵称。

(5)对同一关系的各属性进行约束

职工工资=职工工龄*工龄工资 +职务工资 +......

希望对你有帮助!加油!

若您认为本文内容有益,请不吝赐予赞同并订阅,以便持续接收有价值的信息。衷心感谢您的关注和支持!

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

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

相关文章

王者荣耀使用的UDP通信,十几年编程没用过的协议

缘起 最近在查阅moba相关的资料时,看到了一篇王者荣耀的研发同学的技术分享,从文章中了解到王者荣耀的通信方式是UDP通信,回想到整个职业生涯,貌似并没有用过,今天特地整理下。 udp技术细节 udp协议 UDP协议叫做用…

PTA——1075 链表元素分类、1105 链表合并、1110 区块反转

1075 链表元素分类 解决代码 #include<bits/stdc.h> using namespace std; struct node{int v;int next; }; map<int,node> s; vector<vector<pair<int,int>>> ans(3); vector<pair<int,int>> w; int main(){int st,n,k;cin>>…

web容器导论

一、基础概念 1.Web容器是什么&#xff1f; 让我们先来简单回顾一下Web技术的发展历史&#xff0c;可以帮助你理解Web容器的由来。 早期的Web应用主要用于浏览新闻等静态页面&#xff0c;HTTP服务器&#xff08;比如Apache、Nginx&#xff09;向浏览器返回静态HTML&#xff…

【A-003】基于SSH的校园报刊亭进销存管理系统(含论文)

【A-003】基于SSH的校园报刊亭进销存管理系统&#xff08;含论文&#xff09; 开发环境&#xff1a; Eclipse/MyEclipse、Tomcat8、Jdk1.8 数据库&#xff1a; MySQL 适用于&#xff1a; 课程设计&#xff0c;毕业设计&#xff0c;学习等等 系统介绍 功能需求 系统架构图…

TCP协议 及 重要机制

目录 1.TCP 协议报文格式 1.1.端口号 1.2 首部长度 和 选项 1.3 保留位 1.4 检验和 1.5 32位序号和确认序号 2. TCP的重要机制 2.1 确认应答 2.2 超时重传 2.3 连接管理 2.3.1 三次握手 2.3.2 四次挥手 2.4 滑动窗口 2.5 流量控制 2.6 拥塞控制 2.7 延时应答 2…

投简历没回复?9位DBA公众号集结,快上车!

&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&#x1f61c;&#x1f61c; 中国DBA联盟(ACD…

蓝桥杯之简单数论冲刺

文章目录 取模快速幂 取模 这道题目有两个注意点&#xff1a; 1.当你的取模之后刚好等于0的话&#xff0c;后面就不用进行后面的计算 2.if sum detail[i] > q: 这个语句的等号也很重要 import os import sys# 请在此输入您的代码a,b,n map(int,input().split())week a*5 …

slab分配器

什么是slab分配器&#xff1f; 用户态程序可以使用malloc及其在C标准库中的相关函数申请内存&#xff1b;内核也需要经常分配内存&#xff0c;但无法使用标准库函数&#xff1b;linux内核中&#xff0c;伙伴分配器是一种页分配器&#xff0c;是以页为单位的&#xff0c;但这个…

全网良心开源知识库:AI学习者的宝藏之地

导语&#xff1a;在这个信息爆炸的时代&#xff0c;想要入门AI&#xff0c;找到最一流的学习资源并非易事。然而&#xff0c;有一个地方&#xff0c;能让你免费学习AI&#xff0c;获取最顶尖的知识&#xff0c;还能加入最优秀的AI学习圈。今天&#xff0c;我要向大家推荐的&…

05.自定义指令,插槽和路由配置

一、学习目标 1.自定义指令 基本语法&#xff08;全局、局部注册&#xff09;指令的值v-loading的指令封装 2.插槽 默认插槽具名插槽作用域插槽 3.综合案例&#xff1a;商品列表 MyTag组件封装MyTable组件封装 4.路由入门 单页应用程序路由VueRouter的基本使用 一、自…

大数据 - Spark系列《十四》- spark集群部署模式

Spark系列文章&#xff1a; 大数据 - Spark系列《一》- 从Hadoop到Spark&#xff1a;大数据计算引擎的演进-CSDN博客 大数据 - Spark系列《二》- 关于Spark在Idea中的一些常用配置-CSDN博客 大数据 - Spark系列《三》- 加载各种数据源创建RDD-CSDN博客 大数据 - Spark系列《…

C语言例3-35:长度运算的例子

长度运算符的表现形式&#xff1a; sizeof(数据类型符&#xff09; 或 sizeof(变量&#xff09; 长度运算符的优先级&#xff1a; 与单目算术运算符、单目逻辑运算符、自增和自减运算符的优先级相同。上述优先级相同的运算符的结合性都是从右至左。 长度运算的例子 代码如…

【漏洞复现】Progress Kemp LoadMaster 命令注入漏洞(CVE-2024-1212)

0x01 产品简介 Progress Kemp LoadMaster是一款高性能的应用交付控制器&#xff0c;具有可扩展性&#xff0c;支持实体硬件和虚拟机的负载均衡。它提供了当今应用服务所需的各种功能&#xff0c;包括深度用户验证、资安防护&#xff08;如WAF/IPS/DDoS防护&#xff09;以及零信…

如何写出干净的 Git Commit

大家好&#xff0c;我是楷鹏。 写一份干净的 Git Commit&#xff0c;不仅赏心悦目&#xff0c;也有诸多好处&#xff0c;比如 为项目或者仓库生成 change log方便在其他一些 Git 工具使用&#xff0c;比如 CI/CD、代码协作和审计平台、发版工具等 这是 AngularJS 仓库的 Git …

【C++ leetcode】双指针问题(续)

3. 202 .快乐数 题目 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。如果这个过程 结…

UE5 TPS开发p25 设置大厅,销毁会话,快速退出,检查按钮

这节课主要是完善了菜单选择地图作为游戏大厅,MultiPlayerSessionSubsystem的销毁会话函数,然后就是给Menu菜单添加了Quit和禁止使用按钮 同时还完善了创建房间的漏洞,因为在创建房间的时候如果退出后就马上加入就会发现自己无法创建房间,这是因为服务器判断房间销毁是有一定延…

英伟达 V100、A100/800、H100/800 GPU 对比

近期&#xff0c;不论是国外的 ChatGPT&#xff0c;还是国内诸多的大模型&#xff0c;让 AIGC 的市场一片爆火。而在 AIGC 的种种智能表现背后&#xff0c;均来自于堪称天文数字的算力支持。以 ChatGPT 为例&#xff0c;据微软高管透露&#xff0c;为 ChatGPT 提供算力支持的 A…

大数据爬虫可视化/算法推荐/情感分析——基于python豆瓣电影数据评论情感分析可视化分析推荐系统(完整源码+数据库+详细开发文档+万字论文)

文章目录 大数据可视化/算法推荐/情感分析——基于python豆瓣电影数据评论情感分析可视化分析推荐系统&#xff08;完整源码数据库详细开发文档万字论文&#xff09;源码获取方式在文章末尾源码获取方式在文章末尾一、 背景二、研究目的三、开发技术介绍1、Django框架2、LDA3、…

腾讯云服务器如何购买省钱?2024年优惠券和优惠活动整理

腾讯云代金券领取渠道有哪些&#xff1f;腾讯云官网可以领取、官方媒体账号可以领取代金券、完成任务可以领取代金券&#xff0c;大家也可以在腾讯云百科蹲守代金券&#xff0c;因为腾讯云代金券领取渠道比较分散&#xff0c;腾讯云百科txybk.com专注汇总优惠代金券领取页面&am…

未来教育趋势:AI个性化培训如何推动企业与员工共赢

AI定制学习&#xff1a;重新定义个性化员工培训的未来 随着人工智能&#xff08;AI&#xff09;技术的迅猛发展&#xff0c;我们正目睹并亲历了AI在培训领域所引发的根本性变革。AI技术的整合不仅革新了知识传递的模式&#xff0c;而且重新塑造了个性化学习的内涵。依托于尖端算…