SQL数据库面试题以及答案.docx
- 文档编号:11240909
- 上传时间:2023-02-26
- 格式:DOCX
- 页数:13
- 大小:19.59KB
SQL数据库面试题以及答案.docx
《SQL数据库面试题以及答案.docx》由会员分享,可在线阅读,更多相关《SQL数据库面试题以及答案.docx(13页珍藏版)》请在冰豆网上搜索。
SQL数据库面试题以及答案
Student(S#,Sname,Sage,Ssex)学生表
S#:
学号
Sname:
学生姓名
Sage:
学生年龄
Ssex:
学生性别
Course(C#,Cname,T#)课程表
C#:
课程编号
Cname:
课程名称
T#:
教师编号
SC(S#,C#,score)成绩表
S#:
学号
C#:
课程编号
score:
成绩
Teacher(T#,Tname)教师表
T#:
教师编号:
Tname:
教师名字
问题:
1、查询“001”课程比“002”课程成绩高的所有学生的学号
selecta.S#from(selectS#,scorefromSCwhereC#='001')a,(selects#,scorefromSCwherec#='002')bWherea.score>b.scoreanda.s#=b.s#;
2、查询平均成绩大于60分的同学的学号和平均成绩
selectS#,avg(score)fromscgroupbyS#havingavg(score)>60
3、查询所有同学的学号、姓名、选课数、总成绩
selectstudent.S#,student.Sname,count(sc.C#),sum(score)fromstudentleftouterjoinSConstudent.S#=SC.S#groupbyStudent.S#,Sname
4、查询姓‘李’的老师的个数:
selectcount(distinct(Tname))
fromteacher
wheretnamelike'李%';
5、查询没有学过“叶平”老师可的同学的学号、姓名:
selectstudent.S#,student.Sname
fromStudent
whereS#notin(selectdistinct(SC.S#)fromSC,Course,Teacher
wheresc.c#=course.c#ANDteacher.T#=course.T#ANDTeahcer.Tname='叶平');
6、查询学过“叶平”老师所教的所有课的同学的学号、姓名:
selectS#,SnamefromStudent
whereS#in(selectS#fromSC,Course,Teacher
whereSC.C#=Course.C#andTeacher.T#=Course.T#
andTeacher.Tname='叶平'groupbyS#
havingcount(SC.C#)=(selectcount(C#)fromCourse,Teacher
whereTeacher.T#=Course.T#andTname='叶平'));
7、查询学过“011”并且也学过编号“002”课程的同学的学号、姓名:
selectStudent.S#,Student.Sname
fromStudent,SCwhereStudent.S#=SC.S#
andSC.C#='001'and
exists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002');
8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名:
SelectS#,Sname
from(selectStudent.S#,Student.Sname,score,
(selectscorefromSCSC_2whereSC_2.S#=Student.S#andSC_2.C#='002')score2
fromStudent,SC
whereStudent.S#=SC.S#andC#='001')S_2
wherescore2 9、查询所有课程成绩小于60的同学的学号、姓名: selectS#,sname fromstudent wheres#notin (selectstudent.s#fromstudent,scwheres.s#=sc.s#andscore>60); 10、查询没有学全所有课的同学的学号、姓名: selectstudent.s#,student.sname fromstudent,sc wherestudent.s#=sc.s# groupbystudent.s#,student.sname havingcount(c#)<(selectcount(c#)fromcourse); 11、查询至少有一门课与学号为“1001”同学所学相同的同学的学号和姓名: selects#,Sname fromStudent,SC wherestudent.s#=sc.s# andc#in(selectc#fromSCwheres#='1001'); 12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名; selectdistinctsc.s#,sname fromstudent,sc wherestudent.s#=sc.s# andc#in(selectC#fromscwheres#='001'); 13、把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩: UpdateScSetScore=(SelectAvg(s2_Score)Fromscs2Wheres2.c#=sc.c#) Wherec#IN (Selectc#FromsccsINNERJOINTeachertcONcs.t#=tc.t#WHEREtname='叶平') 14、查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名: selects#fromscwherec#in (selectc#fromscwheres#='1002') groupbys#havingcount(*)= (selectcount(*)fromscwheres#='1002'); 15、删除学习“叶平”老师课的SC表记录: delectsc fromcourse,Teacher wherecourse.c#=sc.c# andcourse.t#=teacher.t# andtname='叶平'; 16、向SC表中插入一些记录,这些记录要求符合以下条件: 没有上过编号“003”课程的同学学号、002号课的平均成绩: InsertSCselectS#,'002', (Selectavg(score)fromSCwhereC#='002') fromStudentwhereS#notin(SelectS#fromSCwhereC#='002'); 17、按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,数据库,企业管理,英语,有效课程数,有效平均分: selects#as学生ID, (selectscorefromscwheresc.s#=t.s#andc#='004')as数据库, (selectscorefromscwheresc.s#=t.s#andc#='001')as企业管理, (selectscorefromscwheresc.s#=t.s#andc#='006')as英语, count(*)as有效课程数,avg(t.score)as平局成绩 fromscast groupbys# orderbyavg(t.score) 18、查询各科成绩最高和最低的分: 以如下的形式显示: 课程ID,最高分,最低分 selectL.c#as课程ID,L.scoreas最高分, R.scoreas最低分 fromscL,scR whereL.c#=R.c# andL.score=(selectmax(IL.score) fromscIL,studentasIM whereL.c#=IL.c#andIM.s#=IL.s# groupbyIL.c#) andR.score=(selectmin(IR.score) fromscasIR whereR.c#=IR.c# groupbyIR.c#); 19、按各科平均成绩从低到高和及格率的百分数从高到低顺序: SELECTt.C#AS课程号, max(course.Cname)AS课程名, isnull(AVG(score),0)AS平均成绩, 100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)AS及格百分数 FROMSCT,Course wheret.C#=course.C# GROUPBYt.C# ORDERBY100*SUM(CASEWHENisnull(score,0)>=60THEN1ELSE0END)/COUNT(*)DESC 20、查询如下课程平均成绩和及格率的百分数(用”1行”显示): 企业管理(001),马克思(002),OO&UML(003),数据库(004): 21、查询不同老师所教不同课程平均分从高到低显示: SELECTmax(Z.T#)AS教师ID, MAX(Z.Tname)AS教师姓名, C.C#AS课程ID, AVG(Score)AS平均成绩 FROMSCAST,CourseASC,TeacherASZ whereT.C#=C.C#andC.T#=Z.T# GROUPBYC.C# ORDERBYAVG(Score)DESC 22、查询如下课程成绩第3名到第6名的学生成绩单: 企业管理(001),马克思(002),UML(003),数据库(004): 23、统计下列各科成绩,各分数段人数: 课程ID,课程名称,[100-85],[85-70],[70-60],[小于60]: SELECTSC.C#as课程ID,Cnameas课程名称, SUM(CASEWHENscoreBETWEEN85AND100THEN1ELSE0END)AS[100-85], SUM(CASEWHENscoreBETWEEN70AND85THEN1ELSE0END)AS[85-70], SUM(CASEWHENscoreBETWEEN60AND70THEN1ELSE0END)AS[70-60], SUM(CASEWHENscore<60THEN1ELSE0END)AS[60-] FROMSC,Course whereSC.C#=Course.C# GROUPBYSC.C#,Cname; 24、查询学生平均成绩及其名次: SELECT1+(SELECTCOUNT(distinct平均成绩) FROM(SELECTS#,AVG(score)AS平均成绩 FROMSC GROUPBYS#)AST1WHERE平均成绩>T2.平均成绩)as名次, S#as学生学号,平均成绩 FROM(SELECTS#,AVG(score)平均成绩 FROMSC GROUPBYS#)AST2 ORDERBY平均成绩desc; 25、查询各科成绩前三名的记录(不考虑成绩并列情况): SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数 FROMSCt1 WHEREscoreIN (SELECTTOP3score FROMSC WHEREt1.C#=C# ORDERBYscoreDESC) 26、查询每门课程被选修的学生数: selectc#,count(s#) fromsc groupbyc#; 27、查询出只选修一门课程的全部学生的学号和姓名: selectsc.s#,student.sname,count(c#)as选课数 fromsc,student wheresc.s#=student.s# groupbysc.s#,Student.sname havingcount(c#)=1; 28、查询男生、女生人数: selectcount(Ssex)as男生人数 fromstudent groupbySsex havingSsex='男'; selectcount(Ssex)as女生人数 fromstudent groupbySsex havingSsex='女'; 29、查询姓“张”的学生名单: selectsname fromstudent wheresnamelike'张%'; 30、查询同名同姓的学生名单,并统计同名人数: selectsanme,count(*) fromstudent groupbysname havangcount(*)>1; 31、1981年出生的学生名单(注: student表中sage列的类型是datetime): selectsname,convert(char(11),DATEPART(year,sage))asage fromstudent whereconvert(char(11),DATEPART(year,Sage))='1981'; 32、查询平均成绩大于85的所有学生的学号、姓名和平均成绩: selectSname,SC.S#,avg(score) fromStudent,SC whereStudent.S#=SC.S# groupbySC.S#,Sname havingavg(score)>85; 33、查询每门课程的平均成绩,结果按平均成绩升序排序,平均成绩相同时,按课程号降序排列: selectC#,avg(score) fromsc groupbyc# orderbyavg(score),c#desc; 34、查询课程名称为“数据库”,且分数低于60的学生名字和分数: selectsname,isnull(score,0) fromstudent,sc,course wheresc.s#=student.s#andsc.c#=course.c#andame='数据库'andscore<60; 35、查询所有学生的选课情况: selectsc.s#,sc.c#,sname,cname fromsc,studentcourse wheresc.s#=student.s#andsc.c#=course.c#; 36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数: selectdistinctstudent.s#,student.sname,sc.c#,sc.score fromstudent,sc wheresc.score>=70andsc.s#=student.s#; 37、查询不及格的课程,并按课程号从大到小的排列: selectc# fromsc wherescore<60 orderbyc#; 38、查询课程编号为“003”且课程成绩在80分以上的学生的学号和姓名: selectsc.s#,student.sname fromsc,student wheresc.s#=student.s#andscore>80andc#='003'; 39、求选了课程的学生人数: selectcount(*)fromsc; 40、查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩: selectstudent.sname,score fromstudent,sc,coursec,teacher wherestudent.s#=sc.S#andsc.c#=c.c# andc.T#=teacher.T# andteacher.tname='叶平' andsc.score=(selectmax(score)fromscwherec#=c.c#); 41、查询各个课程及相应的选修人数: selectcount(*)fromscgroupbyc#; 42、查询不同课程成绩相同的学生和学号、课程号、学生成绩: selectdistincta.s#,b.score fromsca,scb wherea.score=b.score anda.c#<>b.c#; 43、查询每门课程成绩最好的前两名: selectt1.s#as学生ID,t1.c#课程ID,Scoreas分数 fromsct1 wherescorein(selecttop2scorefromsc wheret1.c#=c# orderbyscoredesc) orderbyt1.c#; 44、统计每门课程的学生选修人数(超过10人的课程才统计)。 要求输出课程号和选修人数,查询结果按人数降序排序,若人数相同,按课程号升序排序: selectc#as课程号,count(*)as人数 fromsc groupbyc# orderbycount(*)descc#; 45、检索至少选修两门课程的学生学号: selects# fromsc groupbys# havingcount(*)>=2; 46、查询全部学生选修的课程和课程号和课程名: selectc#,cname fromcourse wherec#in(selectc#fromscgroupbyc#); 47、查询没学过”叶平”老师讲授的任一门课程的学生姓名: selectsname fromstudent wheres#notin(selects#fromcourse,teacher,scwherecourse.t#=teacher.t#andsc.c#=course.c# andtname='叶平'); 48、查询两门以上不及格课程的同学的学号以及其平均成绩: selects#,avg(isnull(score,0)) fromsc wheres#in(selects#fromscwherescore<60groupbys#havingcount(*)>2) groupbys#; 49、检索“004”课程分数小于60,按分数降序排列的同学学号: selects# fromsc wherec#='004' andscore<60 orderbyscoredesc; 50、删除“002”同学的“001”课程的成绩: delectfromsc wheres#='002' andc#='001';
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SQL 数据库 试题 以及 答案