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

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

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

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

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

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

图片说明

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

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

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

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

图片说明
图片说明

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

我想说。。深挖理论有好处,但是也有坏处。

数据库主要理解三大范式,然后就是无限的实践,增删改查的基本SQL语法。

然后就是升级,索引优化,分析等等。

进入当前话题,select 后面加什么字段 ,就会显示什么字段的。

你这条语句就是要查sal=3000的数据,符合条件的有两条,所以会有两个。

至于你说的这段话(我觉的,你还是先学会怎么用,再去学为什么这么用,直接看理论会疯的,仅限个人观点):

书用的是 数据库系统概论(第五版) 人大 王珊版
在看到关系代数投影操作中遇见了一个问题
教材中提到投影是从列的角度进行的运算
如果投影出来新关系,不包括原来的主属性列,那么元组数量有可能会比原关系少
因为关系数据库中不允许有重复元祖出现 所以系统会自动把他们都过滤掉?

数据库中有多条符合条件的数据,就会显示多条数据。
要想只显示一条数据,可以考虑去除重复数据

select 对应的是投影操作,from是连接,where是选择

看了一下书上面的题目,它里面有句话是:投影结果取消了重复的CS元组,所以我觉得意思是select后的结果进行distinct去重
sql应该这样写:

select distinct Sdept from Student 
或者
select distinct job,mgr,sal from emp where sal='3000'

select 投影, where 选择

关系模型不允许出现重复元组。但现实DBMS,却允许出现重复元组,但也允许无重复元组。 在Table中要求无重复元组是通过定义Primary key或Unique来保证的;而在检索结果中要求无重复元组, 是通过DISTINCT保留字的使用来实现的。