【数据库】形式化关系查询语言(一):关系代数Relational Algebra:基本运算、附加关系代数、扩展的关系代数

2024-07-30 09:21:19 浏览数 (1)

一、关系代数Relational Algebra

1. 基本运算

选择、投影和更名运算称为一元运算,因为它们对一个关系进行运算,另外三个运算对两个关系 进行运算.因而称为二元运算。

a. 选择运算(Select Operation)

选择(selelct)运算选出满足给定谓词的元组,用符号σ表示:

选择运算使用一个条件表达式作为参数,对关系中的每个元组进行判断,只有满足条件的元组才会被选取出来,形成一个新的关系。选择运算符通常用符号σ来表示。

选择运算的语法如下: σ<条件表达式>(关系)

其中,条件表达式是一个逻辑表达式,可以使用关系中的属性进行比较和组合。比较运算符(如等于、大于、小于等)和逻辑运算符(如与、或、非等)可以用于构建条件表达式。

选择运算的结果是一个新的关系,其中包含原始关系中满足条件的元组。新关系的模式(属性集合)与原始关系相同。

举个例子,假设有一个关系R,包含属性A、B和C,我们可以使用选择运算来选取满足条件A>5的元组,语法为σ(A>5)(R)。

b. 投影运算(Project Operation)
组合
c. 并运算(Union Operation)

1. 关系r和s必须是同元的,即它们的属性数目必须相同。

2. 对所有的i,r的第i个属性的域必须和s的第i个属性的域相同。

请注意r和s可以是数据库关系或者作为关系代数表达式结果的临时关系。

d. 集合差运算(Set Difference Operation)

用—表示的集合差(set-difference)运算使得我们可以找出在一个关系中而不在另一个关系中的那些元组。表达式r-s的结果即一个包含所有在r中而不在s中的元组的关系。

e. 笛卡尔积运算(Cartesian-Product Operation)
f. 更名运算(Rename Operation)

2. 关系代数的形式化定义

3. 附加关系代数(Additional Operations)

a. 集合交(Set-Intersection Operation)
  • 定义: r ∩ s =
  • 要点:
    • rs 必须包含相同属性,即同元
    • rs 属性的域必须相容
  • 注意,任何使用了集合交的关系代数表达式,我们都可以通过用一对集合差运算替代集合交运 算来重写:

r ∩ s = r − ( r − s )

b. 自然连接(Natural Join Operation)
  • 定义:r⋈s,r 表和 s 表根据重复属性进行笛卡尔积,最后去除重复属性

注意,如果关系r(R)和s(S)不含有任何相同属性,即R ∩ S =0,那么r ∩ s=r X S

  • 例题:
    • 查找计算机学院所有老师的名字以及他们所上课程的名字
    • 查找教授 ‘D.B.S' 和 ’O.S‘ 的老师的名字以及课程名称
c. 除法(Division Operation)
  • 定义:r÷s�÷�
  • R=(A1,A2,...Am,B1,B2,...Bn),S=(B1,B2,...Bn)
  • 解释:前提是 s 表的属性包含于 r 表。则 r 表属性去掉 s 表的属性之后,r 表中包含 s 表所有数据的元组被选出。其实文字比较难以形容,看图理解更好。
  • 应用:带有“包含某某集合所有元素”的问题,可以使用除法解决
  • 例题:
    • 选出选了计算机系所有课程的学生的 ID:∏courseid,ID(takes)÷(∏courseid(σdepartment=′Comp.Sci.′(course)))∏��������,��(�����)÷(∏��������(�����������=′����.���.′(������)))
d. 赋值(Assignment Operation)
  • 定义:temp←expressio,查询结果保存在临时表
e. 外连接运算

4. 扩展的关系代数运算

a. 广义投影(generalized-projection)
b. 聚集(aggregation operation)

二、元组关系演算(Tuple Relational Calculus)

待完善

三、域关系演算(Domain Relational Calculus)

待完善

0 人点赞