数据库 关系运算(关系代数)
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
∨或
.
概述(续)
4.关系代数运算的分类
传统的集合运算
并、差、交、广义笛卡尔积
专门的关系运算
选择、投影、连接、除
.
概述(续)
5.表示记号
(1) R,tR,t[Ai] 设关系模式为R(A1,A2,…,An) 它的一个关系设为R。tR表示t是R的一个元组t[Ai]
则表示元组t中相应于属性Ai的一个分量
• R∪S
– 仍为n目关系,由属于R或属于S的元组组成 R∪S = { t|t R∨t S }
.
并(续)
ABC
R a1 b1 c1 a1 b2 c2 a2 b2 c1 ABC
S a1 b2 c2 a1 b3 c2
ABC R∪S a1 b1 c1
a1 b2 c2 a1 b3 c2 a2 b2 c1
– 行:k1×k2个元组
• R×S = {tr ts |tr R. ∧ tsS }
广义笛卡尔积 (续)
ABC R a1 b1 c1
a1 b2 c2 a2 b2 c1
ABC S a1 b2 c2
a1 b3 c2 a2 b2 c1
A B CA
a1 b1 c1 a1 a1 b1 c1 a1 a1 b1 c1 a2 R × S a1 b2 c2 a1 a1 b2 c2 a1 a1 b2 c2 a2 a2 b2 c1 a1 a2 b2 c1 a1 a2 b2 c1 a2
R-S
.
ABC a1 b1 c1
3. 交(Intersection)
• R和S
– 具有相同的目n – 相应的属性取自同一个域
• R∩S
– 仍为n目关系,由既属于R又属于S的元组组 成 R∩S = { t|t R∧t S } R∩S = R .–(R-S)
交 (续)
ABC
R a1 b1 c1 a1 b2 c2 a2 b2 c1 ABC
S a1 b2 c2
ABC
R ∩ S a1 b2 c2 a2 b2 c1
a1 b3 c2
a2 b2 c1 .
4. 广义笛卡尔积(Extended Cartesian Product)
•R
– n目关系,k1个元组
•S
– m目关系,k2个元组
• R×S
– 列:(n+m)列的元组的集合
• 元组的前n列是关系R的一个元组 • 后m列是关系S的一个元组
– 在关系R中选择满足给定条件的诸元组 σF(R) = {t|tR∧F(t)= '真'}
– F:选择条件,是一个逻辑表达式,基本形式为: [( ] X1θY1 [ )][φ [( ] X2θY2 [ )]]…
• θ:比较运算符(>,≥,<,≤,=或<>) • X1,Y1等:属性名、常量、简单函数;属性名也可以用它
第六讲 关系代数理论
关系数据库模型(3)
.
关系数据库
1. 关系数据模型概述 2. 关系数据模型的结构 3. 关系数据模型的完整性规则 4. 关系代数 5. 关系演算
.
关系模型
1. 关系数据模型的数据结构 2. 关系数据模型的操纵(运算) 3. 关系数据模型的完整性约束
.
关系数据操作
• 关系数据模型的操作
– 查询
• 选择、投影、连接、除、并、交、差
– 数据更新
• 插入、删除、修改
.
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.Leabharlann Baidu
概述
1. 关系代数 2. 运算的三要素 3. 关系代数运算的三个要素 4. 关系代数运算的分类 5. 表示记号
.
概述
1.关系代数 一种抽象的查询语言
用对关系的运算来表达查询
a2 b2 c1 .
2. 差(Difference)
• R和S
– 具有相同的目n – 相应的属性取自同一个域
•R-S
– 仍为n目关系,由属于R而不属于S的所有元组 组成
R -S = { t|tR∧tS }
.
差(续)
ABC R a1 b1 c1
a1 b2 c2 a2 b2 c1 ABC S a1 b2 c2 a1 b3 c2 a2 b2 c1
Zx={t[Z]|t R,t[X]=x} 它表示R中属性组X上值为x的诸元组在Z上分量的集合。
.
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.
传统的集合运算
•并 •差 •交 • 广义笛卡尔积
.
1. 并(Union)
• R和S
– 具有相同的目n(即两个关系都有n个属性) – 相应的属性取自同一个域
.
概述(续)
– (3) tr ts R为n目关系,S为m目关系。tr R,tsS, tr ts称为元组的连接。它是一个n + m列的元 组,前n个分量为R中的一个n元组,后m个 分量为S中的一个m元组。
.
概述(续)
– 4)象集Zx
给定一个关系R(X,Z),X和Z为属性组。当t[X]=x时, x在R中的象集(Images Set)为:
.
概述(续)
(2) A,t[A], A
若A={Ai1,Ai2,…,Aik},其中Ai1,Ai2,…,Aik 是A1,A2,…,An中的一部分,则A称为属性列或 域列。t[A]=(t[Ai1],t[Ai2],…,t[Aik])表示元组t在 属性列A上诸分量的集合。A则表示{A1,A2,…, An}中去掉{Ai1,Ai2,…,Aik}后剩余的属性组。
.
BC
b2 c2 b3 c2 b2 c1 b2 c2 b3 c2 b2 c1 b2 c2 b3 c2 b2 c1
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.
专门的关系运算
• 选择 • 投影 • 连接 •除
.
1. 选择(Selection)
• 1) 选择又称为限制(Restriction) • 2) 选择运算符的含义
.
概述(续)
表 关系代数运算符
运算符 含义 运算符 含义
集 ∪并
比 > 大于
合 -差
较 ≥ 大于等于
运 算
符
∩ ×
交
运
广义笛 卡尔积
算 符
< 小于
≤
小于等于 等于
= 不等于
.
≠
概述(续)
表 关系代数运算符(续)
运算符 含义 运算符 含义
专门的 关系
运算符
σ 选择 π 投影
连接
÷除
逻辑运 非 算符 ∧ 与
.
概述(续)
2.关系代数运算的三个要素
运算对象:关系 运算结果:关系 运算符:四类
.
概述(续)
– 集合运算符
• 将关系看成元组的集合 • 运算是从关系的“水平”方向即行的角度来进行
– 专门的关系运算符
• 不仅涉及行而且涉及列
– 算术比较符
• 辅助专门的关系运算符进行操作
– 逻辑运算符
• 辅助专门的关系运算符进行操作
.
概述(续)
4.关系代数运算的分类
传统的集合运算
并、差、交、广义笛卡尔积
专门的关系运算
选择、投影、连接、除
.
概述(续)
5.表示记号
(1) R,tR,t[Ai] 设关系模式为R(A1,A2,…,An) 它的一个关系设为R。tR表示t是R的一个元组t[Ai]
则表示元组t中相应于属性Ai的一个分量
• R∪S
– 仍为n目关系,由属于R或属于S的元组组成 R∪S = { t|t R∨t S }
.
并(续)
ABC
R a1 b1 c1 a1 b2 c2 a2 b2 c1 ABC
S a1 b2 c2 a1 b3 c2
ABC R∪S a1 b1 c1
a1 b2 c2 a1 b3 c2 a2 b2 c1
– 行:k1×k2个元组
• R×S = {tr ts |tr R. ∧ tsS }
广义笛卡尔积 (续)
ABC R a1 b1 c1
a1 b2 c2 a2 b2 c1
ABC S a1 b2 c2
a1 b3 c2 a2 b2 c1
A B CA
a1 b1 c1 a1 a1 b1 c1 a1 a1 b1 c1 a2 R × S a1 b2 c2 a1 a1 b2 c2 a1 a1 b2 c2 a2 a2 b2 c1 a1 a2 b2 c1 a1 a2 b2 c1 a2
R-S
.
ABC a1 b1 c1
3. 交(Intersection)
• R和S
– 具有相同的目n – 相应的属性取自同一个域
• R∩S
– 仍为n目关系,由既属于R又属于S的元组组 成 R∩S = { t|t R∧t S } R∩S = R .–(R-S)
交 (续)
ABC
R a1 b1 c1 a1 b2 c2 a2 b2 c1 ABC
S a1 b2 c2
ABC
R ∩ S a1 b2 c2 a2 b2 c1
a1 b3 c2
a2 b2 c1 .
4. 广义笛卡尔积(Extended Cartesian Product)
•R
– n目关系,k1个元组
•S
– m目关系,k2个元组
• R×S
– 列:(n+m)列的元组的集合
• 元组的前n列是关系R的一个元组 • 后m列是关系S的一个元组
– 在关系R中选择满足给定条件的诸元组 σF(R) = {t|tR∧F(t)= '真'}
– F:选择条件,是一个逻辑表达式,基本形式为: [( ] X1θY1 [ )][φ [( ] X2θY2 [ )]]…
• θ:比较运算符(>,≥,<,≤,=或<>) • X1,Y1等:属性名、常量、简单函数;属性名也可以用它
第六讲 关系代数理论
关系数据库模型(3)
.
关系数据库
1. 关系数据模型概述 2. 关系数据模型的结构 3. 关系数据模型的完整性规则 4. 关系代数 5. 关系演算
.
关系模型
1. 关系数据模型的数据结构 2. 关系数据模型的操纵(运算) 3. 关系数据模型的完整性约束
.
关系数据操作
• 关系数据模型的操作
– 查询
• 选择、投影、连接、除、并、交、差
– 数据更新
• 插入、删除、修改
.
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.Leabharlann Baidu
概述
1. 关系代数 2. 运算的三要素 3. 关系代数运算的三个要素 4. 关系代数运算的分类 5. 表示记号
.
概述
1.关系代数 一种抽象的查询语言
用对关系的运算来表达查询
a2 b2 c1 .
2. 差(Difference)
• R和S
– 具有相同的目n – 相应的属性取自同一个域
•R-S
– 仍为n目关系,由属于R而不属于S的所有元组 组成
R -S = { t|tR∧tS }
.
差(续)
ABC R a1 b1 c1
a1 b2 c2 a2 b2 c1 ABC S a1 b2 c2 a1 b3 c2 a2 b2 c1
Zx={t[Z]|t R,t[X]=x} 它表示R中属性组X上值为x的诸元组在Z上分量的集合。
.
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.
传统的集合运算
•并 •差 •交 • 广义笛卡尔积
.
1. 并(Union)
• R和S
– 具有相同的目n(即两个关系都有n个属性) – 相应的属性取自同一个域
.
概述(续)
– (3) tr ts R为n目关系,S为m目关系。tr R,tsS, tr ts称为元组的连接。它是一个n + m列的元 组,前n个分量为R中的一个n元组,后m个 分量为S中的一个m元组。
.
概述(续)
– 4)象集Zx
给定一个关系R(X,Z),X和Z为属性组。当t[X]=x时, x在R中的象集(Images Set)为:
.
概述(续)
(2) A,t[A], A
若A={Ai1,Ai2,…,Aik},其中Ai1,Ai2,…,Aik 是A1,A2,…,An中的一部分,则A称为属性列或 域列。t[A]=(t[Ai1],t[Ai2],…,t[Aik])表示元组t在 属性列A上诸分量的集合。A则表示{A1,A2,…, An}中去掉{Ai1,Ai2,…,Aik}后剩余的属性组。
.
BC
b2 c2 b3 c2 b2 c1 b2 c2 b3 c2 b2 c1 b2 c2 b3 c2 b2 c1
关系代数
• 概述 • 传统的集合运算 • 专门的关系运算
.
专门的关系运算
• 选择 • 投影 • 连接 •除
.
1. 选择(Selection)
• 1) 选择又称为限制(Restriction) • 2) 选择运算符的含义
.
概述(续)
表 关系代数运算符
运算符 含义 运算符 含义
集 ∪并
比 > 大于
合 -差
较 ≥ 大于等于
运 算
符
∩ ×
交
运
广义笛 卡尔积
算 符
< 小于
≤
小于等于 等于
= 不等于
.
≠
概述(续)
表 关系代数运算符(续)
运算符 含义 运算符 含义
专门的 关系
运算符
σ 选择 π 投影
连接
÷除
逻辑运 非 算符 ∧ 与
.
概述(续)
2.关系代数运算的三个要素
运算对象:关系 运算结果:关系 运算符:四类
.
概述(续)
– 集合运算符
• 将关系看成元组的集合 • 运算是从关系的“水平”方向即行的角度来进行
– 专门的关系运算符
• 不仅涉及行而且涉及列
– 算术比较符
• 辅助专门的关系运算符进行操作
– 逻辑运算符
• 辅助专门的关系运算符进行操作