e2603199 2017-12-22 05:40 采纳率: 0%
浏览 3092
已结题

关系数据库中,关系代数投影操作的问题

小白一枚
目前自学数据库知识
书用的是 数据库系统概论(第五版) 人大 王珊版

在看到关系代数投影操作中遇见了一个问题

教材中提到投影是从列的角度进行的运算

如果投影出来新关系,不包括原来的主属性列,那么元组数量有可能会比原关系少
因为关系数据库中不允许有重复元祖出现 所以系统会自动把他们都过滤掉?

但是我用Oracle测试了一下,发现不是那么回事儿啊
难道是因为关系数据库理论是这么设计的,但是Oracle出于方便用户或是其他的
什么原因作出了相应改变?
下面是例如

图片说明

按照书中所描述 上图中的数据应该只显示一条啊,因为新关系的两条元组中,所有
属性的数据都是相同的,没有一个属性能够完全区分元组啊

     **谢谢下面几位的解答**,但是我还是觉得现有的几个回答没办法说服我

可能我叙述的不太明白,我知道基本表肯定不允许有重复的数据 因为必须得有主码
我也知道distinct这个语句是去重用的。但是这个问题它确实存在啊。
我已经跳过这段 往下学习了,目前这个还是个问题

下面放上书中的例子把 会比较直观

图片说明
图片说明

  • 写回答

8条回答 默认 最新

  • 沐雨金鳞 2017-12-22 07:10
    关注

    表一共有三总类型:基本表(所谓的关系表),查询表和视图表
    你上面的例子指的是查询表,我们经常说的关系数据库理论是基于基本表的
    查询表的话应该不会过滤掉,这就是所谓的distinct存在的意义
    就是说有几条你就能查出来几条
    希望能被采纳,谢谢

    评论

报告相同问题?

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办