当前位置:   article > 正文

关系数据库标准语言SQL难题整理

关系数据库标准语言SQL难题整理

文章目录

1、查询选修三门以上课程的学生学号

2、查询选修课程中至多一门>70分的学生学号

3、查询平均成绩>=90分的学生学号和平均成绩

4、查询成绩都大于70分学生的成绩

5、找出每个学生超过他自己选修课程平均成绩的课程号

6、查询非计算机科学系某一个学生年龄小的学生姓名和年龄

7、查询非计算机科学系中比计算机学科系所有学生年龄都小的学生姓名和年龄

8、基于 SC表,查询选修了全部课程的学生姓名

9、查询选修了1号课程的学生姓名

10、在 SC表中查询至少选修了1号学生选修的全部课程的学生的学号

11、找出每个学生超过自己选修课程平均成绩的学号和课程号

12、查询所有选修1号课程的学生名字

13、查询所有选课学生的学号、姓名、课程名称及成绩。

14、查询每门课程的课程号、课程名及选课人数。

15、查询每个学生的学号、姓名及选课门数。

16、查询姓张的学生所选修的课程号、课程名称。

17、统计每个同学选修及格的课程的平均分,列出其学号、姓名及平均分。

18、查询选修了课程C1和C2的学生的学号和其各自成绩

19、查询选修了C1和C2课程,并且成绩均大于85分的同学的学号、课程号以及成绩

20、查询每一门课程的间接先修课程号

21、查询跟20201031号学生同学院的学生的学号与姓名

22、查询选修了数据库这门课的学生的学号及姓名

23、查询跟李四在同一个系学习的学生的学号和姓名

24、查询至少有一门课成绩大于70分的学生的学号与姓名

25、查询既选修了C1课程又选修了C2课程的学生的学号

26、查询所选课程成绩全部大于70分的学生的学号

27、查询选修了全部课程的学生的学号和姓名

28、查询至少选修了2020003号学生所选的全部课程的学生的学号与姓名

1、查询选修三门以上课程的学生学号
  1. SELECT Sno
  2. FROM SC
  3. GROUP BY Sno
  4. HAVING COUNT(Cno)>3;
2、查询选修课程中至多一门>70分的学生学号
  1. SELECT Sno
  2. FROM SC
  3. WHERE Sno NOT IN
  4. (SELECT Sno
  5. FROM SC
  6. WHERE Grade >70)
  7. UNION
  8. SELECT Sno
  9. FROM SC
  10. WHERE Grade>70
  11. GROUP BY Sno
  12. HAVING count(Cno)=1 ;
3、查询平均成绩>=90分的学生学号和平均成绩
  1. SELECT Sno,avg(Grade)
  2. FROM SC
  3. GROUP BY Sno
  4. HAVING avg(Grade)>=90;
4、查询成绩都大于70分学生的成绩
  1. SELECT distinct Sno
  2. FROM SC
  3. WHERE Grade NOT IN(
  4. SELECT Grade
  5. FORM SC
  6. WHERE Grade<=70);
5、找出每个学生超过他自己选修课程平均成绩的课程号
  1. SELECT Sno,Cno
  2. FROM SC X
  3. WHERE Grade>=(
  4. SELECT avg(grade)
  5. FROM SC Y
  6. WHERE Y.Sno=X.Sno);
6、查询非计算机科学系某一个学生年龄小的学生姓名和年龄
  1. SELECT Sname,Sage
  2. FROM student
  3. WHERE Sage<ANY(
  4. SELECT Sage
  5. FROM Student
  6. WHERE Sdept='CS')
  7. AND Sdept <>'CS';
7、查询非计算机科学系中比计算机学科系所有学生年龄都小的学生姓名和年龄
  1. SELECT Sname,Sage
  2. FROM student
  3. WHERE Sage<ALL(
  4. SELECT Sage
  5. FROM Student
  6. WHERE Sdept='CS')
  7. AND Sdept <>'CS';
8、基于 SC表,查询选修了全部课程的学生姓名
  1. SELECT Sname
  2. FROM Student
  3. WHERE NOT EXISTS
  4. (SELECT *
  5. FROM Course
  6. WHERE NOT EXISTS
  7. (SELECT *
  8. FROM SC
  9. WHERE Sno=Student.Sno AND Cno=Course.Cno)
  10. );
9、查询选修了1号课程的学生姓名
  1. SELECT Sname
  2. FROM Student
  3. WHERE EXISTS(
  4. SELECT *
  5. FROM SC
  6. WHERE SC.Sno=Student.Sno AND Cno='1');
10、在 SC表中查询至少选修了1号学生选修的全部课程的学生的学号
  1. SELECT DISTINCT SnO
  2. FROM SC SCX
  3. WEHRE NOT EXISTS
  4. (SELECT *
  5. FROM SC SCY
  6. WHERE SCY.SnO='1' AND NOT EXISTS
  7. (SELECT *
  8. FROM SC SCZ
  9. WHERE SCZ.Sno=SCX.Sno AND SCZ.Cno=SCY.Cno)
  10. );
11、找出每个学生超过自己选修课程平均成绩的学号和课程号
  1. SELECT Sno,Cno
  2. FROM SC,(SELECT Sno,avg(Grade)
  3. FROM SC
  4. GROUP BY Sno) AS avgsc(avgsno,avggrade);
  5. WHERE SC.Sno=avgsc.avgsno AND SC.Cno>avgsc.avggrade;
  6. SELECT Sno,Cno
  7. FROM SC x
  8. WHERE Grade>=(SELECT avg(Grade)
  9. FROM SC y
  10. WHERE y.Sno=x.Sno);
12、查询所有选修1号课程的学生名字
  1. SELECT Sname
  2. FROM Student,(SELECT Sno
  3. FROM SC
  4. WHERE Cno='1') AS SC1
  5. WHERE Student.Sno=SC1.Sno;
13、查询所有选课学生的学号、姓名、课程名称及成绩。
  1. select SC.Sno,Sname,Cname,Grade
  2. from SC,Course,Student
  3. where SC.Cno=Course.Cno and Student.Sno=SC.Sno
14、查询每门课程的课程号、课程名及选课人数。
  1. select SC.Cno,Course.Cname,count(Sno)
  2. from SC, Course
  3. where SC.Cno=Course.Cno
  4. group by SC.Cno,Course.Cname
15、查询每个学生的学号、姓名及选课门数。
  1. select SC.Sno,Sname,count(Cno)
  2. from SC,Student
  3. where SC.Sno=Student.Sno
  4. group by SC.Sno,Sname
16、查询姓张的学生所选修的课程号、课程名称。
  1. select distinct SC.Cno,Cname
  2. from SC,Course,Student
  3. where SC.Cno=Course.Cno and Student.Sno=SC.Sno and Sname like '张%'
17、统计每个同学选修及格的课程的平均分,列出其学号、姓名及平均分。
  1. select SC.Sno,Sname,avg(Grade)
  2. from SC,Student
  3. where SC.Sno=Student.Sno and Grade>60
  4. group by Sname,SC.Sno
18、查询选修了课程C1和C2的学生的学号和其各自成绩
  1. select SC1.Sno,SC1.Grade Grade1,SC2.Grade Grade2
  2. from SC SC1,SC SC2
  3. where SC1.Sno=SC2.Sno and SC1.Cno='81001' and SC2.Cno='81002'
19、查询选修了C1和C2课程,并且成绩均大于85分的同学的学号、课程号以及成绩
  1. select SC1.Sno,SC1.Cno Cno1,SC2.Cno Cno2,SC1.Grade Grade1,SC2.Grade Grade2
  2. from SC SC1,SC SC2
  3. where SC1.Sno=SC2.Sno and SC1.Cno='1' and SC2.Cno='2' and SC1.Grade>85 and SC2.Grade>85
20、查询每一门课程的间接先修课程号
  1. select Course1.Cno,Course2.Cpno
  2. from Course Course1,Course Course2
  3. where Course1.Cpno=Course2.Cno
21、查询跟20201031号学生同学院的学生的学号与姓名
  1. select S2.Sno,S2.Sname
  2. from Student S1,Student S2
  3. where S1.Smajor=S2.Smajor and S1.Sno='20180002'
22、查询选修了数据库这门课的学生的学号及姓名
  1. select Student.Sno,Sname
  2. from Student,SC,Course
  3. where SC.Sno=Student.Sno and SC.Cno=Course.Cno and Course.Cname='数据库'
23、查询跟李四在同一个系学习的学生的学号和姓名
  1. select Sno,Sname
  2. from Student
  3. where Sdept in (
  4. select Sdept
  5. from Student
  6. where Sname='李四'
  7. )
24、查询至少有一门课成绩大于70分的学生的学号与姓名
  1. select distinct SC.Sno,Sname
  2. from SC,Student
  3. where SC.Sno=Student.Sno and SC.Grade >70
  4. 或者
  5. select distinct Sno,Sname
  6. from Student
  7. where exists (
  8. select*
  9. from SC
  10. where Student.Sno=SC.Sno and SC.Grade>70
  11. )
25、查询既选修了C1课程又选修了C2课程的学生的学号
  1. select SC.Sno
  2. from SC,(
  3. select Sno
  4. from SC
  5. where Cno='1'
  6. ) S1
  7. where S1.Sno=SC.Sno and SC.Cno='2';
  8. 或者
  9. select SC1.Sno
  10. from SC SC1
  11. where exists (
  12. select *
  13. from SC SC2
  14. where SC1.Sno=SC2.Sno and SC1.Cno='1' and SC2.Cno='2'
  15. )
26、查询所选课程成绩全部大于70分的学生的学号
  1. select distinct SC1.Sno
  2. from SC SC1
  3. where not exists(
  4. select *
  5. from SC SC2
  6. where SC1.Sno=SC2.Sno and (SC2.Grade<70 or SC2.Grade is null)
  7. )
27、查询选修了全部课程的学生的学号和姓名
  1. select Sname
  2. from Student
  3. where not exists(
  4. select *
  5. from Course
  6. where not exists(
  7. select *
  8. from SC
  9. where SC.Sno=Student.Sno and SC.Cno=Course.Cno
  10. )
  11. )
28、查询至少选修了2020003号学生所选的全部课程的学生的学号与姓名
  1. select distinct SCx.Sno,Sname
  2. from SC SCx,Student
  3. where SCx.Sno=Student.Sno and not exists(
  4. select *
  5. from SC SCy
  6. where SCy.Sno='2020003' and not exists(
  7. select *
  8. from SC SCz
  9. where SCz.Sno=SCx.Sno and SCz.Cno=SCy.Cno
  10. )
  11. )
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/389550
推荐阅读
相关标签
  

闽ICP备14008679号