sql语句练习题Word下载.docx
- 文档编号:13162376
- 上传时间:2022-10-07
- 格式:DOCX
- 页数:4
- 大小:16.43KB
sql语句练习题Word下载.docx
《sql语句练习题Word下载.docx》由会员分享,可在线阅读,更多相关《sql语句练习题Word下载.docx(4页珍藏版)》请在冰豆网上搜索。
2.查询平均成绩大于60分的同学的学号和平均成绩;
SELECTsid,avg(score)
FROMsc
GROUPBYsidhavingavg(score)>
60;
此题知识点,GROUPBY语句用于结合合计函数,根据一个或多个列对结果集进行分组。
groupby后面不能接where,having代替了where
3.查询所有同学的学号、姓名、选课数、总成绩
SELECTStudent.sid,Student.Sname,count(SC.cid),sum(score)FROMStudentleftOuterJOINSConStudent.sid=SC.cidGROUPBYStudent.sid,Sname
4.查询姓“李”的老师的个数;
selectcount(teacher.tid)fromteacherwhereteacher.tnamelike'
李%'
5.查询没学过“叶平”老师课的同学的学号、姓名;
SELECTStudent.sid,Student.SnameFROMStudentWHEREsidnotin(SELECTdistinct(SC.sid)FROMSC,Course,TeacherWHERE
SC.cid=Course.cidANDTeacher.id=Course.tidANDTeacher.Tname='
叶平'
);
此题知识点,distinct是去重的作用
6.查询学过“```”并且也学过编号“```”课程的同学的学号、姓名;
selecta.SID,a.SNAMEfrom(selectstudent.SNAME,student.SIDfromstudent,course,scwherecname='
c++'
andsc.sid=student.sidandsc.cid=course.cid)a,
(selectstudent.SNAME,student.SIDfromstudent,course,scwherecname='
english'
andsc.sid=student.sidandsc.cid=course.cid)bwherea.sid=b.sid;
标准答案(但是好像不好使)SELECTStudent.S#,Student.SnameFROMStudent,SCWHEREStudent.S#=SC.S#ANDSC.C#='
001'
andexists(SELECT*FROMSCasSC_2WHERESC_2.S#=SC.S#ANDSC_2.C#='
002'
此题知识点,exists是在集合里找数据,as就是起别名
7.查询学过“叶平”老师所教的所有课的同学的学号、姓名;
selecta.sid,a.snamefrom(selectstudent.sid,student.snamefromstudent,teacher,course,sc
whereteacher.TNAME='
杨巍巍'
andteacher.tid=course.tidandcourse.cid=sc.cidandstudent.sid=sc.sid)a
标准答案:
SELECTsid,SnameFROMStudentWHEREsidin(SELECTsidFROMSC,Course,TeacherWHERESC.cid=Course.cidANDTeacher.tid=Course.tidANDTeacher.Tname='
GROUPBYsidhavingcount(SC.cid)=(SELECTcount(cid)FROMCourse,Teacher
WHERETeacher.tid=Course.tidANDTname='
))
8.查询课程编号“”的成绩比课程编号“”课程低的所有同学的学号、姓名;
selecta.sid,a.snamefrom(selectstudent.SID,student.sname,sc.SCORE
fromstudent,scwherestudent.sid=sc.sidandsc.cid=1)a,
(selectstudent.SID,student.sname,sc.scorefromstudent,scwherestudent.sid=sc.sidandsc.cid=2)bwherea.score<
b.scoreanda.sid=b.sid
SELECTsid,SnameFROM(SELECTStudent.sid,Student.Sname,score,
(SELECTscoreFROMSCSC_2WHERESC_2.sid=Student.sidANDSC_2.cid=1)score2FROMStudent,SC
WHEREStudent.sid=SC.sidANDcid=1)S_2WHEREscore2<
score;
9.查询所有课程成绩小于分的同学的学号、姓名;
SELECTsid,SnameFROMStudentWHEREsidnotin(SELECTStudent.sidFROMStudent,SCWHEREStudent.sid=SC.sidANDscore>
60);
此题知识点,先查出大于60分的,然后notin就是小于60分的了
10.查询没有学全所有课的同学的学号、姓名;
SELECTStudent.sid,Student.Sname
FROMStudent,SC
WHEREStudent.sid=SC.sidGROUPBY
Student.sid,Student.Snamehavingcount(cid)<
(SELECTcount(cid)FROMCourse);
11.查询至少有一门课与学号为“”的同学所学相同的同学的学号和姓名;
12.查询至少学过学号为“”同学所有一门课的其他同学学号和姓名;
SELECTstudent.sid,student.SnameFROMStudent,SCWHEREStudent.sid=SC.sidANDcidin(SELECTcidFROMSCWHEREsid=1)
此题知识点,SELECTsid,SnameFROMStudent,SCWHEREStudent.sid=SC.sidANDcidin(SELECTcidFROMSCWHEREsid=1)这样写是错误的,因为from后面是两个表,不能明确是哪个表里面的sid和sname所以错误提示是“未明确定义列”
13.把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;
updatescsetscore=(selectavg(score)fromsc,course,teacherwherecourse.cid=sc.cidandcourse.tid=teacher.tidandteacher.tname='
)
14.查询和“”号的同学学习的课程完全相同的其他同学学号和姓名;
SELECTsidFROMSCWHEREcidin(SELECTcidFROMSCWHEREsid=6)GROUPBYsidhavingcount(*)=(SELECTcount(*)FROMSCWHEREsid=6);
此题知识点,用数量来判断
15.删除学习“叶平”老师课的SC表记录;
deletefromscswheres.cidin(selectc.cidfromteachert,coursecwheret.tid=c.tidandtname='
李子'
此题知识点,嵌套查询可以分布考虑,先查出李子老师都交了什么课的id,然后再删除那些id的值
16.向SC表中插入一些记录,这些记录要求符合以下条件:
没有上过编号“”课程的同学学号、课程的平均成绩;
InsertintoSCSELECTsid,2,(SELECTavg(score)FROMSCWHEREcid=2)FROMStudentWHEREsidnotin(SELECTsidFROMSCWHEREcid=2);
17.按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示:
学生ID,,数据库,企业管理,英语,有效课程数,有效平均分;
(没做出来)
18.查询各科成绩最高和最低的分:
以如下形式显示:
课程ID,最高分,最低分;
selectcidas课程号,max(score)as最高分,min(score)as最低分fromscgroupbycid
标准答案(但是运行不好使)SELECTL.cidAs课程ID,L.scoreAS最高分,R.scoreAS最低分
FROMSCL,SCASR
WHEREL.cid=R.cidAND
L.score=(SELECTMAX(IL.score)
FROMSCASIL,StudentASIM
WHEREL.cid=IL.cidANDIM.sid=IL.sid
GROUPBYIL.cid)
AND
R.Score=(SELECTMIN(IR.score)FROMSCASIRWHERER.cid=IR.cid
GROUPBYIR.cid);
19.按各科平均成绩从低到高和及格率的百分数从高到低顺序
26.查询每门课程被选修的学生数
selectsc.cid,count(sc.sid)fromsc,coursewheresc.cid=course.cidgroupbysc.cid
27.查询出只选修了一门课程的全部学生的学号和姓名
SELECTSC.sid,Student.Sname,count(cid)AS选课数FROMSC,Student
WHERESC.sid=Student.sidGROUPBYSC.sid,Student.Snamehavingcount(cid)=1;
32.查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SELECTCid,Avg(score)FROMSCGROUPBYcidORDERBYAvg(score),cidDESC;
37.查询不及格的课程,并按课程号
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- sql 语句 练习题