【数据库】|第六章:形式化语言

6.1关系代数

  • 一种过程化查询语言
  • 包括一个运算的集合,以一个或两个关系为输入,产生一个新的关系作为结果

6.1.1 基本运算

在这里插入图片描述

选择运算

  • sigma(σ)表示选择,将谓词写作σ的下标,参数关系写在括号中
  • 谓词的比较: > , = , < , ≤ , ≥ , ≠ >,=,<,≤,≥,\neq >,=,<,,,=
  • 连词:or(⋁),and(⋀),not( ¬ \neg ¬ )

在这里插入图片描述

投影运算

  • 返回作为参数的关系,但把某些属性排除在外
  • 所有重复行均被去除
  • pi(Π),希望在结果中出现的属性作为下标,参数关系在括号中

在这里插入图片描述

并运算

  • r∪s
    • 两关系必须同元,即属性数目必须相同
    • 对所有的i,r的第i个属性必须和s的第i个属性域相同

在这里插入图片描述

差运算-

  • 在一个关系中而不在另一个关系中的元组
  • 保证在相容的关系间进行

笛卡尔积运算

在这里插入图片描述

在这里插入图片描述

更名运算

  • rho(ρ)
    在这里插入图片描述

附加的关系代数运算

用于简化常用的查询

交运算

在这里插入图片描述

自然连接运算

  • A ⋈ B A \Join B AB
  • 首先形成他的参数的笛卡尔积,然后基于两个关系模式中都出现的属性上的相等性进行选择,最后去除重复属性
    在这里插入图片描述

在这里插入图片描述

  • 自然连接是可结合的
  • theta连接:
    • 把一个选择运算和一个笛卡尔积运算合并为单独的一个运算
    • r ⋈ θ s = σ θ ( r × s ) r \Join_{\theta} s=\sigma_{\theta} (r \times s) rθs=σθ(r×s)

赋值运算

  • ⬅:将右侧的表达式的结果赋给左侧的关系变量

外连接运算

左外连接、右外连接、全外连接

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

在这里插入图片描述

关于null
在这里插入图片描述

扩展的关系代数运算

广义投影运算

在这里插入图片描述

  • 允许在投影列表中使用算术运算符和字符串函数等来对投影进行扩展

聚集

在这里插入图片描述

  • 聚集函数:是对输入值的一个汇集,将单一值作为结果返回
  • 去重distinct:附加在函数名后
  • 可以使用更名运算,将其看作聚合操作的一部分

在这里插入图片描述

多重集关系代数
在这里插入图片描述

sql与关系代数
在这里插入图片描述
在这里插入图片描述

元组关系演算

  • 非过程化的查询语言
  • 查询表达:{t|P(t)}
  • 是所有使谓词P为真的元组t的集合
  • 用t[A]表示元组t在属性A上的值
  • 用t∈r表示元组t在关系r中

查询示例

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

形式化定义

  • 自由变量:元组变量不被 ∃ \exists ∀ \forall 修饰,否则称为受限变量
    在这里插入图片描述
    在这里插入图片描述

表达式的安全性

在这里插入图片描述

在这里插入图片描述

语言的表达能力

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

在这里插入图片描述

在这里插入图片描述

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值