数据库系统讲人话系列 关系数据库 关系代数

50 篇文章 3 订阅

附常用名词转化:
【1】关系:即我们脑子里面的一张二维表
【2】元组:某一行数据
【3】域:某一列数据的子集
【4】关系模型: R ( A 1 , A 2 , A 3 . . . ) R(A_1,A_2,A_3...) R(A1,A2,A3...)

关系代数在数据库里面的作用就相当于把我们在 Excel 里面的操作用数学语言表达出来。

第二话:关系代数

1.1 传统集合运算

就是:“交并差”。
R ∩ S R \cap S RS R ∪ S R\cup S RS R − S R - S RS

注意,我们对关系进行传统集合运算的时候,必须保证:两个关系的属性完全一致!

1.2 专门集合运算

1.2.1 投影 projection

投影实质上是就是属性选择器
格式:
π a 1 , a 2 . . . ( R ) \pi_{a_1,a_2...}(R) πa1,a2...(R)

举例子:已知关系Student(二维表)

agenameclassdeptnumber
11ZW1CS01001
10VCD2CS02003
12NMG1CS01002
9KLJ1CS01003
11HG2IS02004

那么 π a g e , n u m b e r ( S t u d e n t ) \pi_{age,number}(Student) πage,number(Student)运算之后的结果:

agenumber
1101001
1002003
1201002
901003
1102004
1.2.2 选择 selection

是元组选择器。也就是选中行
格式:
σ c o n d i t i o n s ( R ) \sigma_{conditions}(R) σconditions(R)
conditions 写的是行选择条件。
举例子:
对上面二维表 σ d e p t = ′ I S ′ ( S t u d e n t ) \sigma_{dept='IS'}(Student) σdept=IS(Student) 运算之后,得到:

agenameclassdeptnumber
9KLJ1CS01003

如果,对关系进行投影和选择组合操作的话,我们需要优先操作“选择”。

1.2.3 连接 join

对一张二维表操作还远远不够,我们需要考虑到把两个关系(二维表)进行合并的情况。这时,我们就需要Join运算。

在学Join运算之前,我们需要知道笛卡尔积 :R x S。

假如,现在有R和S两个关系,满足:
R:n个属性,k1个元组
S:m个属性,k2个元组

那么R x S之后得到的笛卡尔积的大二维表满足:
m+n个属性,k1*k2个元组。

笛卡尔运算实际上就是在关系里面我们按一个元组作为最小的同类元素,我们对这个数组的每个元素搭配另外一个数组的每个元素。
在这里插入图片描述
当我们需要对两个表进行合并的时候,必然涉及到一些谁去谁留的问题,我们利用笛卡尔积可以先把所有的结果都呈现出来,然后再进行运算筛选。

连接操作的格式:
在这里插入图片描述

R join S
a条件b

a和b分别是R和S的列名
实际上等价于 σ a 条 件 b ( R X S ) \sigma_{a条件b}(R X S) σabRXS

单单这样的连接并没有太大意义,我们一般常会使用两种连接:等值连接自然连接

等值连接

等值连接的意义: σ R . a = S . a ( R X S ) \sigma_{R.a=S.a}(R X S) σR.a=S.aRXS

例子:
在这里插入图片描述

自然连接

而自然连接实际上就是再等值连接的基础上,去除相同的公共的属性列。
我们直接写,就表示默认自然连接:
R ∞ S R \infty S RS

例子:
在这里插入图片描述

1.3 组合运算

1.3.1 基础组合运算

已知有四个关系(表):(加粗的是主键 Primary Key)
T(TID,TNAME,TITLE)
C(CID,CN,CNAME,TID)
S(SID,SNAME,AGE,SEX)
SC(SID,CID,SCORE)

现在,我们需要用关系代数来实现以下运算:

【1】检测课程号为C2的学生的学号和成绩

思考:
给定某个属性的查询,就是选择,然后再对选择结果进行一次投影即可。(注意,我们要优先操作“selection”)

π S I D , S C O R E ( σ C I D = ′ C 2 ′ ( S C ) ) \pi_{SID,SCORE}(\sigma_{CID='C2'}(SC)) πSID,SCORE(σCID=C2(SC))

【2】检测课程号为C2的学生的学号和姓名

思考:
当我们进行一次选择之后,发现SC表里面没有姓名这个属性,如果我们需要姓名就需要到表S里面拿,我们需要增加数据,这时就需要到自然连接Join操作了。

π S I D , S N A M E ( σ C I D = ′ C 2 ′ ( S C ) ∞ S ) \pi_{SID,SNAME}(\sigma_{CID='C2'}(SC)\infty S) πSID,SNAME(σCID=C2(SC)S)

【3】检索至少选修Liu老师的课程中一门课程的学生的学号和姓名

π S I D , S N A M E ( σ T N A M E = ′ L i u ′ ( T ) ∞ C ∞ S C ∞ S ) \pi_{SID,SNAME}(\sigma_{TNAME='Liu'}(T)\infty C \infty SC \infty S) πSID,SNAME(σTNAME=Liu(T)CSCS)

【4】检索选修课程号为C2或者C4课程的学生学号

π S I D ( σ C I D = ′ C 2 ′ ∨ C I D = ′ C 4 ′ ( S C ) ) \pi_{SID}(\sigma_{CID='C2' \vee CID='C4'}(SC)) πSID(σCID=C2CID=C4(SC))

易错:
【5】检索选修课程号是C2和C4课程的学生学号
思考,我们把 ∨ \vee 换成 ∧ \wedge 就对了吗?
不对!!

假如是:
π S I D ( σ C I D = ′ C 2 ′ ∧ C I D = ′ C 4 ′ ( S C ) ) \pi_{SID}(\sigma_{CID='C2' \wedge CID='C4'}(SC)) πSID(σCID=C2CID=C4(SC))

表示出现歧义,CID到底是C2还是C4?注意的是,CID只能等于一个值。

现在是选修C2的学生和选修C4的学生。
应该要写成:
π S I D ( σ C I D = ′ C 2 ′ ( S C ) ∩ σ C I D = ′ C 4 ′ ( S C ) ) \pi_{SID}(\sigma_{CID='C2'}(SC) \cap \sigma_{CID='C4'}(SC)) πSID(σCID=C2(SC)σCID=C4(SC))

如何表达否定?我们使用传统的差即可
【6】检索不学C2课程的学生姓名和年龄
首先我们先选出学的学生:
π S N A M E , A G E ( σ C I D = ′ C 2 ′ ( S C ) ∞ S ) \pi_{SNAME,AGE}(\sigma_{CID='C2'}(SC)\infty S) πSNAME,AGE(σCID=C2(SC)S)

再用全部减去即可:
π S N A M E , A G E ( S ) − π S N A M E , A G E ( σ C I D = ′ C 2 ′ ( S C ) ∞ S ) \pi_{SNAME,AGE}(S)-\pi_{SNAME,AGE}(\sigma_{CID='C2'}(SC)\infty S) πSNAME,AGE(S)πSNAME,AGE(σCID=C2(SC)S)

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 程序猿惹谁了 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值