一道易错题检验关系代数掌握情况(含详细解答)

一、前言

在数据库中的关系代数部分知识点的时候,会有一个初学者很容易犯的错误,包括博主本人第一次在做的时候也踩坑了,所以分享给各位小伙伴,避免出现类似情况,如果忘记了知识点的话,可以回顾一下这篇文章【关系模型知识点总结(3)—— 关系操作中的关系代数(含题目及详细分析)

二、题目

Customer

客户编号(cid)姓名(cname)性别(csex)地址(caddress)邮编(czip)电话(ctel)年龄(cage)
44000001李琦上海市黄浦区南京路1号2000011381889345620
44000002张岩上海市浦东新区石桥路28弄2001201331017445630
44000003陈冬广州市越秀区北京路186号5100301392505666922
44000004刘敏广州市越秀区八旗二马路68号5101151380229782527

Orders

订单编号(oid)客户编号(cid)商品编号(gid)订购金额(oamount)订购数量(osum)订购日期(orderdate)
1440000011502000128082022-9-12
1440000021501000114999922022-9-12
14400000215020001999932022-9-25
1440000031503000129942022-9-30
14400000515010002699932022-10-5

Goods

商品编号(gid)商品名称(gname)商品类型(gtype)型号(model)库存量(gstock)单价(gprice)
15010001lv包包奢侈品人造皮革10149999
15010002格力空调家用电器两匹半426999
15020001西门子冰箱家用电器630立升39999
15030001口红化妆品色号999色号99979

根据Customer,Orders,Goods三个关系,用关系代数表达式表示:查询客户“张岩”购买的商品名称及购买数量

三、解题思路

1.在customer表中找到并提取张岩的客户编号(cid)

这里需要先提取出来张岩这一行(选择),然后将代表他客户编号的列提取出来,与下一张表组成新的表,即自然连接Orders表,以便在第二张Orders表中通过cid提取出它的gid并组成新的表,即 投影

  • σcname=‘张岩’(Customers)
  • Πcid( σcname=‘张岩’(Customers))

2.将提取出来的cid与Orders表连接后提取商品编号(gid)

这里使用自然连接投影

  • Πcid( σcname=‘张岩’(Customers))⋈ Orders
  • Πcid、gid( σcname=‘张岩’(Customers))⋈ Orders

3.连接Goods表后提取出订购数量(osum)和商品名称(gname)并组成新表

同样地,自然连接投影

  • Πcid、gid( σcname=‘张岩’(Customers))⋈ Orders ⋈ Goods
  • Πosum、gname(Πcid、gid( σcname=‘张岩’(Customers))⋈ Orders ⋈ Goods)

四、易错点

这里的易错点在于当我们第一步提取出来cid以后,想到如果在Orders表周末和找到一个cid=提取出来的cid的元组,不就能再提取出来它的osumgid,投影形成新的表了吗?同样的操作提取出来gnamegid投影形成新的表,两表一连接就完事儿了

但是有个致命的错误:提取出来的属性形成的是一个只含一个元素的表,不能等于一个值

Πcid( σcname=‘张岩’(Customers))的结果如下:

客户编号(cid)
44000002

所以不能出现类似 cid = Πcid( σcname=‘张岩’(Customers))的操作

五、其它注意事项

  • 当我们运用选择的运算时,如果出现两个及以上的条件,要用来连接
  • 不可以用逗号隔开

例如:
要选择一个年龄大于20岁且是男性的客户,应该这么写:σcage>20∧csex=‘男’(Customer)

六、结语

本文的例题需要读者先自己做一遍,体会一下过程再看详细解答,有任何问题欢迎评论留言

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alita11101_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值