数据库系统概论(个人笔记)(第二部分)

news2025/1/16 13:57:51

数据库系统概论(个人笔记)

文章目录

  • 数据库系统概论(个人笔记)
  • 2、关系模型简介
    • 2.1 关系数据库的结构
    • 2.2 数据库模式
    • 2.3 键
    • 2.4 模式图
    • 2.5 关系查询语言
    • 2.6 关系代数

2、关系模型简介


2.1 关系数据库的结构

Structure of Relational Databases

在逻辑级别上,关系数据库是一个名为 Relations 的二维表的集合。

Relations 表示一个实体集或一个关系集。 (集合)

Relations 的一行表示一个实体或一个关系。(个体)

在这里插入图片描述


Basic Structure

关系的每一行都可以称为元组 tuple

关系的每一列都有一个名称 → 关系的命名列称为属性 attributes

每个属性允许的值的集合称为属性的域 domain

属性值(通常)必须是原子的 atomic ;也就是说,它是不可分割的:

  • 属性上的元组的值可以是一个帐号,但不能是一组帐号

特殊值 null 是每个域的成员。

在这里插入图片描述


Relation

笛卡尔积 Cartesian Product

在这里插入图片描述
在这里插入图片描述


Tuple Variable

元组变量 Tuple Variable

  • 是一个变量,代表一个元组
  • 其域是一个特定关系的所有元组的集合

在这里插入图片描述


2.2 数据库模式

Database Schema

Relation Schema

关系模式 relation schema

在这里插入图片描述


Relations are Unordered

元组的顺序是无关的(元组可以以任意顺序存储)。

在这里插入图片描述


Relational Database

一个数据库由多个关系组成。

有关企业的信息被分成若干部分,每个关系存储一部分信息。

在这里插入图片描述

将所有信息存储为一个简单的 relation。

university(instr_id, inst_name, stu_id, stu_name,...)

  • 重复的信息——(会导致)如果两个导师给一个学生建议(What gets repeated?)
  • 空值的需要——来代表一个没有老师的学生

规范化理论(第7章)涉及如何设计关系模式


2.3 键

Keys

K 是一组属性,设K ⊆ R

如果 K 的值足以识别每个可能关系 r® 的唯一元组,则K是R的超键 superkey

  • ”可能的 r“ 是指可能存在于我们正在建模的企业中的关系。

在这里插入图片描述

如果K最小,则超键 K 为候选密钥 candidate key

  • 极小意味着它的任何子集都不是超级密钥

在这里插入图片描述

主键 Primary key:作为识别关系中元组的主要手段而选择的候选键

  • 应该选择一个其值永远或很少改变的属性

电子邮件地址是唯一的,但可能会改变,不适合主键


Foreign Keys

关系 r1 可能具有与另一个关系 r2 的主键相对应的属性。该属性称为外键 foregin key

  • r1 是引用关系 r1 is referencing relation
  • r2 是被引用的关系 r2 is referenced relation

在这里插入图片描述

在这里插入图片描述


Referencing Constraint

Referencing Constraint 引用约束

只有出现在被引用关系 referenced relation 的主键属性中的值才可能出现在引用关系 referencing relation 的外键属性中

在这里插入图片描述


2.4 模式图

Schema Diagrams

Schema Diagram for University Database

在这里插入图片描述


2.5 关系查询语言

Relational Query Languages

用户从数据库请求信息的语言。

语言类别

  • 程序性
  • 非程序性,或声明性

“纯 Pure” 的语言: 形成人们使用的查询语言的基础

  • 关系代数 程序性
  • 元组关系演算 非程序性
  • 域关系演算 非程序性

以上3种纯语言在计算能力上是等价的在本章中

我们将集中讨论关系代数

  • 不是图灵机等价物
  • 由6个基本操作组成

2.6 关系代数

The Relational Algebra

一种由一组操作组成的过程语言,这些操作把一个或两个关系作为输入,并产生一个新的关系作为其结果。

六种基本运算符
select 选择σ
project 投影
union 并
set difference 集合差-
Cartesian product 笛卡尔积×
rename 重命名ρ

Select Operation

选择满足给定谓词的元组

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述


Project Operation

一元操作,选取某些列

在这里插入图片描述

在这里插入图片描述

结果被定义为通过擦除未列出的列而获得的k列之间的关系

从结果中删除重复行,因为关系是集

在这里插入图片描述


Composition of Relational Operations

关系代数运算的结果是关系,因此关系代数运算可以组合成一个关系代数表达式 reletional-algebra expression

考虑这个查询——查找物理系所有教员的姓名。
∏ n a m e = ( σ d e p t . . n a m e   =   " P h y s i c s " " ( i n s t r u c t o r ) ) ) \prod _{name}=(\sigma _{dept..name\,=\,"Physics""}(instructor))) name=(σdept..name="Physics""(instructor)))
我们不给出关系的名称作为投影操作的参数,而是给出一个计算结果为关系的表达式。


Union Operation

类似于集合并运算

在这里插入图片描述

在这里插入图片描述

对 r ∪ s 才有效:

  1. r,s 必须具有相同的参数数量 arity (相同数量的属性)
  2. 属性域必须兼容 compatible

r 的第二列处理的值与 s 的第二列处理的值类型相同

在这里插入图片描述


Set Difference Operation

类似于集合差运算

在这里插入图片描述

在这里插入图片描述

集合差必须处在兼容关系之间

  • R和S必须具有相同的参数数量 arity
  • 属性R和S的域必须兼容

在这里插入图片描述


Set-Intersection Operation

Set-Intersection Operation 交集运算

在这里插入图片描述

Example

在这里插入图片描述
在这里插入图片描述


Cartesian-Product Operation

将一个关系的每个元组与另一个关系的每个元组配对

在这里插入图片描述
在这里插入图片描述

Composition of Operations***

可以使用多个运算生成表达式

在这里插入图片描述
在这里插入图片描述

The instructor x teaches table

在这里插入图片描述


Join Operation

Join Operation 连接运算

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


Rename Operation

允许我们命名,从而引用关系代数表达式的结果

在这里插入图片描述

允许我们用多个名称来引用一个关系

在这里插入图片描述
在这里插入图片描述


The Assignment Operation

The Assignment Operation 赋值运算

有时通过将关系代数表达式的一部分分配给临时的关系变量来编写关系代数表达式是很方便的。

赋值操作用<–表示,其工作方式类似于程序设计语言中的赋值操作。

在这里插入图片描述

通过赋值操作,可以将查询编写为一个顺序程序,该程序由一系列赋值和一个表达式组成,表达式的值显示为查询的结果。


Equivalent Queries

Equivalent Queries 相同的查询

在关系代数中编写查询的方法不止一种。

在这里插入图片描述
在这里插入图片描述

这两个查询并不相同。但是,它们是等价的——它们在任何数据库上都给出相同的结果。

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

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

相关文章

【目标检测】YOLOv5|YOLOv8模型QT界面可视化部署

YOLO-Deploy-QT_Interface 最近笔者做了YOLO系列算法的部署工作,现做一个总结。主要工作是做了用于部署YOLOv5和YOLOv8的可视化QT界面,可实现图片、文件夹、视频、摄像头的ONNX与OpenVino部署,具体效果如下: 代码链接:https://github.com/Zency-Sun/YOLO-Deploy-QT_Inte…

开源之夏又有新项目发布!快来认领!¥12,000 奖金等你来!

又有新项目加入开源之夏啦&#xff01;KubeBlocks 的亲兄弟 WeScale 也加入开源之夏啦&#xff01;一起来了解下 WeScale 社区及它带来的项目吧&#xff01; WeScale 是什么&#xff1f; WeScale 社区源自对更好的数据库访问体验的追求。在现代应用程序开发中&#xff0c;数据…

一文扫盲(13):电商管理系统的功能模块和设计要点

电商管理系统是一种用于管理和运营电子商务平台的软件系统。它提供了一系列功能模块&#xff0c;帮助企业进行商品管理、订单管理、会员管理、营销推广、数据分析等工作。本文将从以下四个方面介绍电商管理系统。 一、什么是电商管理系统 电商管理系统是一种集成了各种功能模块…

Android Q - 音频通路调试

对于当前模块不是很清楚&#xff0c;刚好有个项目这方面有点问题&#xff0c;根据展锐支持文档一步步检查就可以了。首先得先弄清楚硬件具体是怎么连接的&#xff0c;比如文档提到的案例&#xff1a;sprd codec speaker output 连接外部 PA。 耳机接的是什么&#xff0c;speake…

国产化开源鸿蒙系统智能终端RK3568主板在电子班牌项目的应用

国产化开源鸿蒙系统智能终端主板AIoT-3568A、人脸识别算法的的电子班牌方案可支持校园信息发布、人脸识别考勤、考场管理、查询互动等多项功能&#xff0c;助力学校在硬件上实现信息化、网络化、数字化&#xff0c;构建“学校、教师、学生”三个维度的智慧教育空间。 方案优势 …

mysql5和mysql8同时存在

Win10安装两个不同版本MySQL数据库&#xff08;一个5.7&#xff0c;一个8.0.17&#xff09;_两个数据库的版本不同(我本地的是mysql5.7,线上是mysql8),怎么进行数据的同步?-CSDN博客 安装两个版本的mysql出现的问题和解决_mysql安装两个版本其中一个不适用-CSDN博客 一台电脑…

增程SUV价格即将崩盘?买车一定要再等等!

文 | AUTO芯球 作者 | 雷歌​ 真是“离谱”啊&#xff0c;车圈真是逗比欢乐多&#xff0c; 我这两天看一个博主连续40多小时开车直播&#xff0c;充电口、油箱盖全部封死&#xff0c;全程视频直播没断过&#xff0c; 就为了测试这两天刚上市的星际元ET续航有多远。 另一个…

drippingblues 靶机实战

信息收集&#xff1a; Nmap: 存活&#xff1a; 靶机ip&#xff1a;192.168.10.110 端口&#xff1a; 服务&#xff1a; 发现ftp服务可以匿名登录。且用户名是FTP。 发现一个压缩包&#xff0c;下载并爆破。 得到密码 072528035。发现关键字 drip。里面还有一个 secret.zip(…

C语言写扫雷游戏(数组和函数实践)

目录 最后是代码啦&#xff01; 手把手教你用C语言写一个扫雷游戏&#xff01; 1.我们搭建一下这个多文件形式的扫雷游戏文件结构 2.在主函数里面设置一个包含游戏框架的菜单 菜单可以方便游戏玩家选择要进行的动作和不断地进行下一局。 3.switch语句连接不同的结果 菜单可…

49.乐理基础-拍号的类型-单拍子、复拍子

当前写的东西&#xff0c;如果只是想要看懂乐谱的话&#xff0c;它是没什么意义的&#xff0c;就像我们要把 0&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5。。。称为自然数&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5称为正整…

【提示学习论文】TCP:Textual-based Class-aware Prompt tuning for Visual-Language Model

TCP:Textual-based Class-aware Prompt tuning for Visual-Language Model&#xff08;CVPR2024&#xff09; 基于文本的类感知提示调优的VLMKgCoOp为baseline&#xff0c;进行改进&#xff0c;把 w c l i p w_{clip} wclip​进行投影&#xff0c;然后与Learnable prompts进行…

考研数学|强化《660》+《880》这样刷,太丝滑了❗️

660题880题需要大概两个月才能做完 660题和880题都是很高质量的题集&#xff0c;所以做起来一点也不轻松。 每年都会有学生暑假两个月只做了一本660题的情况&#xff0c;因为题目实在是太难&#xff0c;有点做不下去的感觉。 不过不要担心&#xff0c;暑假就是刷题发现问题的…

Ubuntu安装k8s集群

文章目录 Ubuntu安装k8s3台主机前置操作&#xff1a;3台主机k8s前置安装命令&#xff1a;k8s安装命令&#xff1a; 节点加入 Ubuntu安装k8s 官方文档&#xff1a;https://kubernetes.io/zh-cn/docs/setup/production-environment/tools/kubeadm/install-kubeadm/ 默认3台机子 注…

如何为域名生成证书签发请求CSR

最近我们在Hostease购买了服务器产品&#xff0c;为了保障我们网站的安全&#xff0c;我们额外还购买了SSL证书产品。在Hostease技术客服的帮助下&#xff0c;我们成功签发了SSL证书。 在签发证书前需要生成一个证书签名请求CSR&#xff0c;证书签名请求(CSR)是一个包含有关你…

轻松拿下指针(5)

文章目录 一、回调函数是什么二、qsort使用举例三、qsort函数的模拟实现 一、回调函数是什么 回调函数就是⼀个通过函数指针调⽤的函数。 如果你把函数的指针&#xff08;地址&#xff09;作为参数传递给另⼀个函数&#xff0c;当这个指针被⽤来调⽤其所指向的函数 时&#x…

Autoware内容学习与初步探索(一)

0. 简介 之前作者主要是基于ROS2&#xff0c;CyberRT还有AutoSar等中间件完成搭建的。有一说一&#xff0c;这种从头开发当然有从头开发的好处&#xff0c;但是如果说绝大多数的公司还是基于现成的Apollo以及Autoware来完成的。这些现成的框架中也有很多非常好的方法。目前作者…

uniapp高性能图片裁剪插件,可添加水印

效果图&#xff1a; 插件地址&#xff1a;高性能图片裁剪&#xff0c;裁剪图片后自动添加水印 - DCloud 插件市场 示例&#xff1a; <template> <view><button click"select">选择图片</button><image mode"widthFix" :src&qu…

EUCR-30S电机保护器施耐德EOCR

​EOCR主要产品有电子式电动机保护继电器&#xff0c;电子式过电流继电器&#xff0c;电子式欠电流继电器&#xff0c;电子式欠电压继电器&#xff0c;其它保护和监视装置&#xff0c;电流互感器。 电器密集型设计 ■ 二个集成组装电流互感器 ■ 欠载保护&#xff08;空转保护…

解决使用Vue.js前端与Flask后端API交互时跨源资源共享问题

我在使用flask以及Vue做一个项目时遇到了Vue前端与Flask后端API交互的问题就是前端获取不到后端返回的数据&#xff0c;报错&#xff1a; 上网查说是跨域问题&#xff0c;于是找了一些解决办法&#xff0c;就是可以通过设置响应头的 Access-Control-Allow-Origin 字段来允许所有…

pve clusterk8s cluster重建

背景 dev环境新买了一块固态&#xff0c;插到pve主板的第二个M.2槽位不能识别&#xff0c;通过其他机器排查后确定是这台pve的槽位问题。 同时这台pve还有一些其他的lvm历史遗留问题&#xff0c;具体表现是每次开机很长&#xff0c;因为要扫描那块机械硬盘做的lvm 所以决定将这…