关系代数是一种集合操作为基础过程化查询语言,特点:运算对象是关系,运算结果亦为关系

一、关系代数的特点

运算对象:关系

运算结果:关系

运算符:四类

  • 集合运算符
  • 专门的关系运算符
  • 算术比较符
  • 逻辑运算符

二、关系代数运算符

运算符类型 运算符 含义
集合运算符

集合运算符 -
集合运算符
集合运算符 ×

广义笛卡尔积

比较运算符

大于
比较运算符

大于等于
比较运算符 小于
比较运算符

小于等于
比较运算符 =     等于
比较运算符 不等于
专门的关系运算符

σ

选择

专门的关系运算符 π 投影
专门的关系运算符 连接
专门的关系运算符 ÷
逻辑运算符

¬

逻辑运算符
逻辑运算符

三、运算规则

1.集合运算规则

将关系R, S看作是元组的集合,进行交、并及差集合运算,必须具备下列条件:

  • R和S的模式必须相同
  • R和S的属性顺序也相同
表达式 操作类型 含义
R ∪ S R、S两者中元组的集合,一个元素在并集中只出现一次
R ∩ S 同时存在于R和S中的元组的集合
R – S 在R中存在,而在S中不存在的元素的集合
R × S 笛卡尔积 R(n目p元组),S(m目q元组);运算得到的新关系中有(n+m)个目(p×q)个元组

解析:

广义笛卡尔积运算

2.专门的关系运算符

表达式 操作类型 含义 备注 举例
σ c (R) 选择 在关系R上选择满足条件C的元组,构成一个新的关系。新关系是R的子集,模式与R相同 条件 c 是一个逻辑表达式,表达式中可以使用比较运算符和逻辑运算符 σ name = '小明' (Student)
π A1,A2,…,An (R) 投影 从关系R产生一个只有R的某些列的新的关系 新的关系中含有旧关系的A1,A2,…,An 列 π name,age (Student)
R⋈ AθB S θ连接 从两个关系R,S的广义笛卡尔积中选择属性间满足一定条件的元组;记作S⋈R(AθB)

A为包含R中的属性的表达式,B为包含S中的属性的表达式,θ通常为关系比较符;

等效于σ AθB (R×S)

Student ⋈ sGPA≥cGPA Company
R⋈ A=B S 等值连接 当比较运算符θ 为 = 时的θ连接

A为包含R中的属性的表达式,B为包含S中的属性的表达式;

等效于σ A=B (R×S)

Student ⋈ sGPA=cGPA Company
R⋈S 自然连接 一种特殊的等值连接。两个关系中进行比较的分量必须是相同的属性组。在结果中把重复的属性列去掉   Student ⋈ GPA
R÷S

详解见本文最后

详解见本文最后 详解见本文最后

解析:

自然连接

除法运算:

=======================================================================================================

为什么把这个分支知识点放到最后单独来说呢?因为它的概念确实是比较抽象的,单独靠一个表格确实无法深入的理解,下面我们一步一步来了解什么是关系代数中的除运算

(1)象集

关系R(A,Z)

A和Z为关系R的属性,a是属性A中的分量值

a在R中的象集:R中在A上值为a元组在Z属性上对应分量的集合

例如:

(2)除

首先我们来看一下官方定义:

除运算是同时从关系的水平方向和垂直方向进行运算。给定关系R(X,Y)和S(Y,Z),X、Y、Z为属性组。R÷S应当满足元组在X上的分量值x的象集Y,包含关系S在属性组Y上投影的集合

分析:

关系 R (A,Y)、S (Y,Z)

P(A) = R÷S      (经过除法运算得到一个新的关系P(A))

关系R在A上分量值a的象集 称作 seta

关系S在Y属性组上投影的集合 称作setY

若seta包含了 setY,  则 a 就是关系P中的元组分量

例如:

关系R和关系S拥有共同的属性Cno、R÷S得到的新关系中存在着“关系R包含但关系S不包含“”的属性,即Sno属性

=======================================================================================================

MySQL入门,第六部分,关系代数的更多相关文章

  1. 21分钟 MySQL 入门教程(转载!!!)

    21分钟 MySQL 入门教程 目录 一.MySQL的相关概念介绍 二.Windows下MySQL的配置 配置步骤 MySQL服务的启动.停止与卸载 三.MySQL脚本的基本组成 四.MySQL中的数 ...

  2. MySQL入门笔记

    MySQL入门笔记 版本选择: 5.x.20 以上版本比较稳定 一.MySQL的三种安装方式: 安装MySQL的方式常见的有三种: ·          rpm包形式 ·          通用二进制 ...

  3. MySQL入门转载

    21分钟 MySQL 入门教程 http://www.cnblogs.com/mr-wid/archive/2013/05/09/3068229.html 目录 一.MySQL的相关概念介绍 二.Wi ...

  4. MySQL入门笔记(二)

    MySQL的数据类型.数据库操作.针对单表的操作以及简单的记录操作可参考:MySQL入门笔记(一) 五.子查询   子查询可简单地理解为查询中的查询,即子查询外部必然还有一层查询,并且这里的查询并非仅 ...

  5. MySQL入门介绍(mysql-8.0.13)

    MySQL入门介绍(mysql-8.0.13单机部署) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL数据库介绍 1>.MySQL是一种开放源代码的关系型数据库 ...

  6. mysql入门与进阶

    MySQL入门与进阶 需求:对一张表中的数据进行增删改查操作(CURD) C:create 创建 U:update 修改 R:read 读|检索 查询 D:delete 删除涉及技术:数据库 1.数据 ...

  7. 【数据库】7.0 MySQL入门学习(七)——MySQL基本指令:帮助、清除输入、查询等

    1.0 help == ? 帮助指令,查询某个指令的解释.用法.说明等.详情参考博文: [数据库]6.0 MySQL入门学习(六)——MySQL启动与停止.官方手册.文档查询 https://www. ...

  8. Mysql学习总结(12)——21分钟Mysql入门教程

    21分钟 MySQL 入门教程 目录 一.MySQL的相关概念介绍 二.Windows下MySQL的配置 配置步骤 MySQL服务的启动.停止与卸载 三.MySQL脚本的基本组成 四.MySQL中的数 ...

  9. MySQL入门——在Linux下安装和卸载MariaDB

    MySQL入门——在Linux下安装和卸载MariaDB 摘要:本文主要学习了如何在Linux系统中安装和卸载MariaDB数据库. 查看有没有安装过MariaDB 使用命令查看有没有安装过: [ro ...

  10. 最新MySQL入门篇

    一.SQL简介 ​ SQL:结构化查询语言(Structured Query Language),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系 ...

随机推荐

  1. feign源码解读

    对于feign的接口请求失败的重试配置可通过如下自定义配置文件实现(一般不建议配置) @Configuration public class FeignConfig { @Bean public Re ...

  2. c 将年月日转化为星期

    /*得到年月日转化为星期几*/ LOCAL ulong_t DateWeekGet(ulong_t year,ulong_t month,ulong_t day) { ulong_t c = ; ul ...

  3. Python只有文件不存在才能写文件

    当我们在Python里面写文件时,我们常用的模式为 w模式,这种模式下,如果文件不存在,就会生成文件:如果文件已经存在,就会直接覆盖. 有时候,如果文件已经存在,直接覆盖文件可能会导致重要数据丢失.你 ...

  4. [译]ABP框架v2.3.0已经发布!

    在新冠病毒的日子里,我们发布了ABP框架v2.3, 这篇文章将说明本次发布新增内容和过去的两周我们做了什么. 关于新冠病毒和我们的团队 关于冠状病毒的状况我们很难过.在Volosoft的团队,我们有不 ...

  5. Python基础篇(三)_函数及代码复用

    Python基础篇_函数及代码复用 函数的定义.使用: 函数的定义:通过保留字def实现. 定义形式:def <函数名>(<参数列表>): <函数体> return ...

  6. 告别炼丹,Google Brain提出强化学习助力Neural Architecture Search | ICLR2017

    论文为Google Brain在16年推出的使用强化学习的Neural Architecture Search方法,该方法能够针对数据集搜索构建特定的网络,但需要800卡训练一个月时间.虽然论文的思路 ...

  7. Scapy编写ICMP扫描脚本

    使用Scapy模块编写ICMP扫描脚本: from scapy.all import * import optparse import threading import os def scan(ipt ...

  8. Drawing Simple Polygon(Create Simple Polygon from unordered points by angle sorting)

    Keywords: 极角排序, Simple Polygon Generation Given set of points in the plane, your task is to draw a p ...

  9. cmdb客户端代码完善2

    目录: 1.面试提问 2.完善采集端代码 3.唯一标识的问题 4.API的验证 1.面试会问到的问题: # 1. 为啥要做CMDB?# - 实现运维自动化, 而CMDB是实现运维自动化的基石# - 之 ...

  10. P4147 玉蟾宫 题解

    原题链接 简要题意: 求最大 \(0\) 矩阵.(将字符转化为数字) 本题是模板题,可以用来爆踩.??? 悬线法 来了! 其中绿色是 \(0\),红色是 \(1\). 下面以这个图为例讲一下算法流程. ...