数据库原理(关系型数据库基本理论)——(

一、关系的概念

1.关系的定义

(1)域

        域是一组具有相同数据类型的值的集合,可以理解为int[](int类型的数组)是一个域。

(2)笛卡儿积

        简单来说,若干个域的笛卡儿积就是将这几个域的元素进行排列组合,即:

D1 =【Q、G、Y】,基数为3

D2 = 【1、2】,基数为2

则:笛卡儿积D1 * D2如下所示: 

D1D2
Q1
Q2
G1
G2
Y1
Y2

该笛卡儿积的基数为3*2=6 

(3)关系

        N个域(D1~DN)的笛卡儿积的子集称为这N个域上的一个N元关系,表示为:

R(D1, D2, D3, ......, DN)

如下,为上述域D1,D2的一个二元关系:

D1D2
Q1
G2

这里注意:当N = 1时叫单元关系,不叫一元关系。 

2.相关术语

  • 元组和属性:表中的每一行对应着一个元组,每一列对应着一个属性;
  • 候选码与主码:可以唯一标识元组的属性(如学生id)或属性组(如学生id与图书id找借书记录)为候选码,其中最小的为主码;
  • 主属性和非主属性:出现在候选码中的属性为主属性,没有的就是非主属性。

二、关系数据模型

1.关系模型及其要素

(1)关系模型的数据结构

        关系的描述称作关系模式,关系模式即关系的框架或结构,其形式化表示为

R(U,D,dom,F)

其中的含义分别为

  • R:关系名;
  • U:关系的属性集;
  • D:属性组中属性所来自的域;
  • dom:属性向域的映像集合;
  • F:属性间的数据依赖关系;

(2)关系操作

        关系操作包括数据更新、数据控制和数据查询。关系操作语言有下面几个:

  • 关系代数语言(ISBL);
  • 关系演算语言(ALPHA、实例查询语言);
  • 具有关系代数及关系演算双重特点的语言,结构化查询语言(SQL)是关系数据库的标准语言。

(3)关系完整性约束

  • 域完整性,例:学生关系中的性别只能是男或女;
  • 实体完整性:不能出现相同的元组(不是属性),且主属性的值不能为空值;
  • 参照完整性:又称为引用完整性,指一个表的外键(如专业id)不能出现引用表中没有的主键(如专业表的id);
  • 用户定义的完整性,例:图书关系中的价格不能为负数。

2.关系的性质及类型

(1)关系的性质

  • 同一列的数据具有同质性,即来自同一个域;
  • 关系中所有属性值都是原子的,即不可分割;
  • 同一关系中每一列对应一个属性;
  • 关系中不允许有完全相同的元组;
  • 在一个关系中元组的次序是无关紧要的;
  • 在一个关系中属性次序是无关紧要的。

(2)关系的类型:基本表,查询表和视图表。

三、关系代数

1.关系代数概述

  • 集合运算符:并运算\bigcup、交运算\bigcap、差运算—、广义笛卡儿积\times
  • 关系运算符:选择运算\sigma、投影运算\prod、连接运算\bowtie、除法运算\div
  • 比较运算符:大于>、小于<、不小于>=、不等于!=、等于=;
  • 逻辑运算符:非¬、与∧、或∨。

2.关系代数运算

数据库速成课之关系代数运算_哔哩哔哩_bilibili

3.关系演算(这里只对此知识点进行简单讲解我也不太会

(1)元组关系演算

        (\forallt)(\Phi)表示对所有的t,使\Phi都为真,则 (\forallt)(\Phi)为真,反之则为假;而(\existst)(\Phi)表示若存在一个t使得\Phi为真,则(\existst)(\Phi)为真。

题例:

查询作者“任民宏”编写的《数据库原理与应用》的图书单价,其中书名在第二列,作者在第四列,单价在第七列。

{t|(\existsu)(图书(u)∧u[2]='数据库原理与应用')∧u[4]='任民宏'∧t[1]=u[7]}

解释:

        t是新表的属性,只有一个图书单价,u是图书表的属性,该题题意为这本图书既是’数据库原理与应用‘并且作者是’任民宏‘,则两个条件用∧连接,最后将符合条件的图书价格赋给新表的第一个属性。

查询借阅了图书编号为“JSJ101”图书的读者卡号和姓名,其中借阅表和读者表的读者id在第一列,借阅表的图书id在第二列,读者表的读者姓名在第二列。

{t|(\existsu)(\existsv)(借阅(u)∧读者(v)∧u[1]=v[1]∧u[2]='JSJ101'∧t[1]=u[1]∧t[2]=v[2])}

解释:

        这里t是新表属性,u为借阅表属性,v为读者表属性,这里要注意的是新表这时候有两个属性。

查询没有借阅图书编号为“JSJ101”图书的读者卡号,表中关系同上。

{t|(\existsu)(\forallv)(读者(u)∧借阅(v)∧(u[1]=v[1]\rightarrowv[2]\neq'JSJ101')∧t[1]=u[1])}

解释:

        其中\rightarrow是推出符号,就是从左边可以推出右边,这个题我也没太看懂,背背吧,注意是这里借阅用的是\forall(我觉得是因为这里题目变成了没有借阅)。

(2)域关系演算

查询借阅了图书编号为“JSJ101”图书的读者卡号和姓名,表关系同上。

{t_1t_2|(\existsu_1u_2u_3u_4)(\existsv_1v_2v_3v_4v_5v_6v_7)(借阅(u_1u_2u_3u_4)∧读者(v_1v_2v_3v_4v_5v_6v_7)∧u_1=v_1u_2='JSJ101'∧t_1=u_1t_2=v_2)}

查询没有借阅图书编号为“JSJ101”图书的读者卡号,表关系同上。

{t_1|(\exists u_1u_2u_3u_4u_5u_6u_7)(\forall v_1v_2v_3v_4)(读者(u_1u_2u_3u_4u_5u_6u_7)\Lambda借阅(v_1v_2v_3v_4)\Lambda (u_1=v_1\rightarrow v_2\neq 'JSJ101')\Lambda t_1=u_1)

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

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

相关文章

RMAN-06023 FRA 和DATA永远不要放在一起

由于FRA 和DATA放在一起&#xff0c;BACKUPSET PDB里面是和datafile放在一起的&#xff0c;再一串数据的目录里&#xff0c;正常会认为这个目录包含的是datafile. ASMCMD> ls DATA1/CDB/0633F844101D69CBE0636401A8C09D55/BACKUPSET/2024_06_15/nnndf0_tag20240615t223219_0…

MySQL日志(三):数据安全

先来看一个结论&#xff1a;只要redo log和binlog保证持久化到磁盘&#xff0c; 就能确保MySQL异常重启后&#xff0c; 数据可以恢复。 binlog写入逻辑 binlog的写入逻辑比较简单&#xff1a; 事务执行过程中&#xff0c; 先把日志写到binlog cache&#xff0c; 事务提交的时候…

腾讯测试开发复试<硬核面经>

隔天捞测试开发-腾讯云&#xff0c;硬核90min 3.27 状态返回初面 2h 自我介绍你的项目实习中sql的基本操作&#xff0c;用到了sql实现什么样的功能&#xff0c;或者场景给你一个场景&#xff0c;比如两个客户端都要去操作同一条数据这时候会发生什么现象&#xff0c;你如何处…

Linux:线程池

Linux&#xff1a;线程池 线程池概念封装线程基本结构构造函数相关接口线程类总代码 封装线程池基本结构构造与析构初始化启动与回收主线程放任务其他线程读取任务终止线程池测试线程池总代码 线程池概念 线程池是一种线程使用模式。线程过多会带来调度开销&#xff0c;进而影…

2024.06.03 校招 实习 内推 面经

1、提前批 | RoboSense 速腾聚创 2025届全球校园招聘提前批启动-免笔试&#xff08;内推&#xff09; 提前批 | RoboSense 速腾聚创 2025届全球校园招聘提前批启动-免笔试&#xff08;内推&#xff09; 2、校招 | 星纵物联2025届校园招聘全面启动&#xff01; 校招 | 星纵物联…

PyTorch -- nn.Module 快速实践

网络层父类 nn.Module&#xff1a;Evrey Layer is nn.Module (nn.Linear, nn,Conv2d …)具体的&#xff0c;我们在定义自已的网络时&#xff1a;需要继承 nn.Module&#xff0c;并重新实现 __init__ 方法: 一般放置网络中具有可学习参数的层&#xff08;如全连接层、卷积层等&a…

STM32CubeMX配置-外部中断配置

一、简介 MCU为STM32G070&#xff0c;配置为上升沿触发外部中断&#xff0c;在上升沿外部中断回调函数中进行相关操作。 二、外部中断配置 查看规格书中管教描述&#xff0c;找到I/O对应的外部中断线&#xff0c;然后进行如下上升沿触发外部中断配置。 三、生成代码 调用上升沿…

【 Python高级编程】Matplotlib中xlabel 和 xticks参数的区别

xlabel 和 xticks 是 Matplotlib 中用于处理 x 轴标签的两个函数&#xff1a; xlabel 设置 x 轴的标签。仅设置标签文本&#xff0c;不影响刻度位置或格式。 xticks 设置 x 轴的刻度位置和标签。接受两个参数&#xff1a;位置和标签。可以用来自定义刻度的位置和格式。 主…

JavaScript 规范霍夫曼编码

霍夫曼编码是一种无损数据压缩算法&#xff0c;其中数据中的每个字符都分配有可变长度的前缀代码。出现频率最低的字符获得最大代码&#xff0c;出现频率最高的字符获得最小代码。使用这种技术对数据进行编码非常简单且高效。但是&#xff0c;解码使用此技术生成的比特流效率低…

Parallels Desktop 19 激活码 - 苹果 Mac 最新版 PD 19激活密钥虚拟机下载 (支持Win11/macOS Sonoma)

Parallels Desktop 被称为 macOS 上强大的虚拟机软件。可以在 Mac 下同时模拟运行 Win、Linux、Android 等多种操作系统及软件而不必重启电脑&#xff0c;并能在不同系统间随意切换。 最新版 Parallels Desktop 19 (PD19) 完全支持 macOS Sonoma、Ventura 和 Windows 11 / Win…

【Ardiuno】实验使用OPT语音模块播放语音(图文)

当我们需要在程序中播放语音内容时&#xff0c;就需要使用到语音模块&#xff0c;今天我们就来实验一下使用OPT语音模块来方法语音。 const int voicePin 5; const int voiceBusyPin 18; const int testLEDPin 2;unsigned long pmillis 0;int busyVal 0; …

LeetCode | 125.验证回文串

这道题一开始的想法是把原字符串的非数字英文字符去掉&#xff0c;然后判断剩下的字符串是否为回文串即可&#xff0c;其中去掉非数字英文字符可以遍历一遍字符串依次处理&#xff0c;也可以用正则表达式&#xff0c;然后判断是否是回文串只需要两个指针&#xff0c;一头一尾&a…

OpenCV目标识别

一 图像轮廓 具有相同颜色或强度的连续点的曲线。 图像轮廓的作用 可以用于图像分析 物体的识别与检测 注意 为了检测的准确性&#xff0c;需要先对图像进行二值化或Canny操作。 画轮廓时会修改输入的图像。 轮廓查找的API findContours(img,mode,ApproximationMode,...)…

代码随想录算法训练营第十天| 232.用栈实现队列|225. 用队列实现栈|20. 有效的括号|1047. 删除字符串中的所有相邻重复项

232.用栈实现队列 文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;栈的基本操作&#xff01; | LeetCode&#xff1a;232.用栈实现队列_哔哩哔哩_bilibili 知道要用两个栈实现&#xff0c;具体咋做忘了。队列的特性是先进先出&#xff0c;栈是先进后出&#xff0c;入队操…

upload-labs第八关教程

upload-labs第八关教程 一、源代码分析代码审计 二、绕过分析点绕过上传eval.php使用burp suite进行抓包修改放包&#xff0c;查看是否上传成功使用中国蚁剑进行连接 一、源代码分析 代码审计 $is_upload false; $msg null; if (isset($_POST[submit])) {if (file_exists(U…

推箱子-小游戏

学习目标&#xff1a; 巩固Java基础&#xff0c;数据类型、二维数组、条件语句等&#xff1b; 效果展示&#xff1a;

CSS【详解】样式选择器的优先级(含提升优先级的方法)

数值越大&#xff0c;优先级越高&#xff0c;尽量保持较低的优先级&#xff0c;以便使用更高优先级的选择器重置样式 0级——通配选择器、选择符和逻辑组合伪类。逻辑组合伪类有:not()、:is()和:where等&#xff0c;这些伪类本身并不影响CSS优先级&#xff0c;影响优先级的是括…

Python基础用法 之 变量

1.变量的定义 变量的作用&#xff1a;是⽤来保存数据的。定义的语法&#xff1a;变量名 数据值使用&#xff1a;直接使⽤变量名 即可使⽤变量中存储的数据。注意&#xff1a;变量必须先定义后使用。 (即 必须 先存⼊数据 才能 获取数据) 。 # 需求 1, 定义⼀个变量 保存你的名…

flutter中采用腾讯云COS进行图片存储

首先配置文件添加 flutter_cos: ^0.0.3 添加COS配置 import dart:io; import dart:io; import dart:convert; import package:http/http.dart as http; import package:http/http.dart;class CosConfig {final String appid;final String region;final String bucket;CosCon…

(超详细)基于动态顺序表实现简单的通讯录项目

前言&#xff1a; 我们在上一章节用c语言实现了线性表中的的动态顺序表&#xff0c;那么顺序表就只是顺序表吗&#xff1f;当然不是&#xff0c;使用顺序表结构可以实现很多项目&#xff0c;许多项目的数据结构都会用到顺序表&#xff0c;本章节我们就要使用顺序表实现一个简易…