首页数据库数据库关系代数例题,求助 这道数据库 关系代数表达式的题目 的答案

数据库关系代数例题,求助 这道数据库 关系代数表达式的题目 的答案

编程之家2023-10-1984次浏览

大家好,数据库关系代数例题相信很多的网友都不是很明白,包括求助 这道数据库 关系代数表达式的题目 的答案也是一样,不过没有关系,接下来就来为大家分享关于数据库关系代数例题和求助 这道数据库 关系代数表达式的题目 的答案的一些知识点,大家可以关注收藏,免得下次来找不到哦,下面我们开始吧!

数据库关系代数例题,求助 这道数据库 关系代数表达式的题目 的答案

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

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

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.姓名=“王英杰”

求助 这道数据库 关系代数表达式的题目 的答案

--1.检索“吴迪”老师讲授的课程号和课程名

select cno,cname,teacher from c where teacher='吴迪'

--2.检索所有女同学和年龄小于20岁的男同学

select* from s where

数据库关系代数例题,求助 这道数据库 关系代数表达式的题目 的答案

s.sex='男' and age<20 or s.sex='女'

--3.检索至少选修“吴迪”老师讲授课程中一门课的学生姓名

select sname from s where sno in(select sno from sc where cno in(select cno from c where teacher='吴迪'))

--4.检索“李波”同学不学的课程的课程名

select cname from c where cno in(select cno from sc where sno not in(select sno from s where sname='李波'))

--5.检索至少选修两门课程的学生的姓名

select sname from s where sno in(select sno from(select COUNT(sno) as'scNumber',sno from sc group by sno) scs where scNumber>=2)

--6.检索未被选修的课程的课程名

select cname from c where cno not in(select cno from sc)

--7.检索选修全部课程的学生的学号

select sno from s where sno in(select sno from(select COUNT(sno) as'scNumber',sno from sc group by sno) scs where scNumber=(select COUNT(distinct c.cname) from c))

--8.检索选修了“吴迪”老师讲授课程的学生的学号

select sno from s where sno in(select sno from sc where cno in(select cno from c where teacher='吴迪'))

--9.检索选修了“吴迪”老师讲授课程且成绩高于85的学生的学号sele

select sno from s where DEPT>85 and sno in(select sno from sc where cno in(select cno from c where teacher='吴迪'))

--10.检索“王虎”同学所学课程的课程号

select cno from sc where sno=(select sno from s where sname='王虎')

--11.检索选修了C01和C02两门课程的学生的姓名

select sname from s where sno in( select sc.sno from sc where sc.sno in(select sc.sno from sc where sc.cno=(select c.cno from c where c.cname='c01'))and sc.cno=(select c.cno from c where c.cname='c02'))

--12.检索未选修课程的学生的学号

select sno from s where sno not in(select sno from sc) select* from sc

数据库系统中的习题,关系代数的表达,6个问题

[例]设教学数据库中有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)查询计算机系年龄小于等于20岁的学生姓名:

selectSNfromSwhereAGE<=20anddept='计算机系'

(2)查询修读课程号为c1的所有学生的姓名:

selectSNfromSwhereS#in(selectdistinctS#fromSCwhereC#=(

selectC#fromCwhereCN='c1'))

(3)查询修读课程名为JAVA的所有学生姓名

selectSNfromSwhereS#in(selectdistinctS#fromSCwhereC#=(

selectC#fromCwhereCN='JAVA'))

(4)查询所有成绩都不及格的学生姓名

selectSNfromSwhereS#in

(

--以学号分组得到最小分数having过滤不及格的分数得到的学生ID!

selectS#from(

--查询所有学生所有课程的分数

select*,isnull(GRADE,0)from(selectS#,C#fromS,C)templeftjoinSContemp.S#=SC.S#andtemp.C#=SC.C#)temp

groupbyS#havingmin(GRADE)<60

)

案例如上:

希望能帮到你!

关于数据库关系代数例题和求助 这道数据库 关系代数表达式的题目 的答案的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

域名转向(域名转向功能有什么作用)云服务器哪个好用 有哪些云服务器比较好