一道数据库关系代数的题目?

一道数据库关系代数的题目?,第1张

①检索职称是“工程师”的职工所参加的项目名称,研制费

Select J.名称,J.研制费 from J,E,J_E where J.项目编号=J_E.项目编号 and E.职工编号=J_E.职工编号 and E.职称=“工程师”

②检索2011年前已完成2项或2项以上软件项目的公司名称和联系电话

Select J.公司,S.联系电话 from J,S where J.完成日期<"2011" group by 项目编号 count(*)>=2

③检索至少参加了编号为‘E01’职工所参加的全部项目的职工编号,姓名

Select E.职工编号, E.姓名 from J,E,J_E where J.项目编号=J_E.项目编号 and E.职工编号=J_E.职工编号 and J.项目编号=‘E01’

④检索职工“王英杰”没有参加的项目编号和名称

Select J.项目编号, J.名称 from J,E,J_E where J.项目编号=J_E.项目编号 and E.职工编号=J_E.职工编号 and E.姓名=“王英杰”

[例]设教学数据库中有3个关系:

学生关系S(SNO,SNAME,AGE,SEX)

学习关系SC(SNO,CNO,GRADE)

课程关系C(CNO,CNAME,TEACHER)

下面用关系代数表达式表达每个查询语句。

(1) 检索学习课程号为C2的学生学号与成绩。

πSNO,GRADE(σ CNO='C2'(SC))

(2) 检索学习课程号为C2的学生学号与姓名

πSNO,SNAME(σ CNO='C2'(SSC))

由于这个查询涉及到两个关系S和SC,因此先对这两个关系进行自然连接,同一位学生的有关的信息,然后再执行选择投影 *** 作。

此查询亦可等价地写成:

πSNO,SNAME(S)(πSNO(σ CNO='C2'(SC)))

这个表达式中自然连接的右分量为"学了C2课的学生学号的集合"。这个表达式比前一个表达式优化,执行起来要省时间,省空间。

(3)检索选修课程名为MATHS的学生学号与姓名。

πSNO,SANME(σ CNAME='MATHS'(SSCC))

(4)检索选修课程号为C2或C4的学生学号。

πSNO(σ CNO='C2'∨CNO='C4'(SC))

(5) 检索至少选修课程号为C2或C4的学生学号。

π1(σ1=4∧2='C2'∧5='C4'(SC×SC))

这里(SC×SC)表示关系SC自身相乘的乘积 *** 作,其中数字1,2,4,5都为它的结果关系中的属性序号。

1

select 学号,课名 from 选课,课程

where 成绩<60 and 选课.课号=课程.课号

2

select 课名 from 课程

where 选课.课号!=课程.课号

3

select 学号 from 选课

where 课号 in (select 课号 from 选课 where 学生.学号=选课.学号 and 学生.姓名=‘王一’)


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9886978.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存