sql面试题经典Word文档下载推荐.docx
- 文档编号:21304905
- 上传时间:2023-01-29
- 格式:DOCX
- 页数:40
- 大小:35.96KB
sql面试题经典Word文档下载推荐.docx
《sql面试题经典Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《sql面试题经典Word文档下载推荐.docx(40页珍藏版)》请在冰豆网上搜索。
李%'
;
5、查询没学过“叶平”老师课的同学的学号、姓名;
selectStudent.S#,Student.Sname
fromStudent
whereS#notin(selectdistinct(SC.S#)fromSC,Course,Teacherwhere
SC.C#=Course.C#andTeacher.T#=Course.T#andTeacher.Tname='
叶平'
);
6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;
selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='
andexists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='
7、查询学过“叶平”老师所教的所有课的同学的学号、姓名;
selectS#,Sname
fromStudent
whereS#in(selectS#fromSC,Course,TeacherwhereSC.C#=Course.C#andTeacher.T#=Course.T#andTeacher.Tname='
groupbyS#havingcount(SC.C#)=(selectcount(C#)fromCourse,Teacher
whereTeacher.T#=Course.T#andTname='
));
8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;
SelectS#,Snamefrom(selectStudent.S#,Student.Sname,score,(selectscorefromSCSC_2whereSC_2.S#=Student.S#andSC_2.C#='
)score2
fromStudent,SCwhereStudent.S#=SC.S#andC#='
)S_2wherescore260);
10、查询没有学全所有课的同学的学号、姓名;
fromStudent,SC
whereStudent.S#=SC.S#groupby
Student.S#,Student.Snamehavingcount(C#)=60THEN1ELSE0END)/COUNT(*)AS及格百分数
FROMSCT,Course
wheret.C#=course.C#
GROUPBYt.C#
ORDERBY100*SUM(CASEWHEN
isnull(score,0)>
=60THEN1ELSE0END)/COUNT(*)DESC
20、查询如下课程平均成绩和及格率的百分数(用"
1行"
显示):
企业管理(001),马克思(002),OO&
UML(003),数据库(004)
SELECTSUM(CASEWHENC#='
THENscoreELSE0END)/SUM(CASEC#WHEN'
THEN1ELSE0END)AS企业管理平均分
100*SUM(CASEWHENC#='
ANDscore>
=60THEN1ELSE0END)/SUM(CASEWHENC#='
THEN1ELSE0END)AS企业管理及格百分数
SUM(CASEWHENC#='
THEN1ELSE0END)AS马克思平均分
THEN1ELSE0END)AS马克思及格百分数
003'
THEN1ELSE0END)ASUML平均分
THEN1ELSE0END)ASUML及格百分数
004'
THEN1ELSE0END)AS数据库平均分
THEN1ELSE0END)AS数据库及格百分数
FROMSC
21、查询不同老师所教不同课程平均分从高到低显示
SELECTmax(Z.T#)AS教师ID,MAX(Z.Tname)AS教师姓名,C.C#AS课程ID,MAX(C.Cname)AS课程名称,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)
[学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
SELECT
DISTINCTtop3
SC.S#As学生学号,
Student.SnameAS学生姓名,
T1.scoreAS企业管理,
T2.scoreAS马克思,
T3.scoreASUML,
T4.scoreAS数据库,
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)as总分
FROMStudent,SC
LEFTJOINSCAST1
ONSC.S#=T1.S#ANDT1.C#='
LEFTJOINSCAST2
ONSC.S#=T2.S#ANDT2.C#='
LEFTJOINSCAST3
ONSC.S#=T3.S#ANDT3.C#='
LEFTJOINSCAST4
ONSC.S#=T4.S#ANDT4.C#='
WHEREstudent.S#=SC.S#and
ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)
NOTIN
(SELECT
DISTINCT
TOP15WITHTIES
FROMsc
LEFTJOINscAST1
ONsc.S#=T1.S#ANDT1.C#='
k1'
LEFTJOINscAST2
ONsc.S#=T2.S#ANDT2.C#='
k2'
LEFTJOINscAST3
ONsc.S#=T3.S#ANDT3.C#='
k3'
LEFTJOINscAST4
ONsc.S#=T4.S#ANDT4.C#='
k4'
ORDERBYISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)DESC);
23、统计列印各科成绩,各分数段人数:
课程ID,课程名称,[100-85],[85-70],[70-60],[
24、查询学生平均成绩及其名次
SELECT1+(SELECTCOUNT(distinct平均成绩)
FROM(SELECTS#,AVG(score)AS平均成绩
FROMSC
GROUPBYS#
)AST1
WHERE平均成绩>
T2.平均成绩)as名次,
S#as学生学号,平均成绩
FROM(SELECTS#,AVG(score)平均成绩
)AST2
ORDERBY平均成绩desc;
25、查询各科成绩前三名的记录:
(不考虑成绩并列情况)
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
FROMSCt1
WHEREscoreIN(SELECTTOP3score
WHEREt1.C#=C#
ORDERBYscoreDESC
)
ORDERBYt1.C#;
26、查询每门课程被选修的学生数
selectc#,count(S#)fromscgroupbyC#;
27、查询出只选修了一门课程的全部学生的学号和姓名
selectSC.S#,Student.Sname,count(C#)AS选课数
fromSC,Student
whereSC.S#=Student.S#groupbySC.S#,Student.Snamehavingcount(C#)=1;
28、查询男生、女生人数
Selectcount(Ssex)as男生人数fromStudentgroupbySsexhavingSsex='
男'
Selectcount(Ssex)as女生人数fromStudentgroupbySsexhavingSsex='
女'
;
29、查询姓“张”的学生名单
SELECTSnameFROMStudentWHERESnamelike'
张%'
30、查询同名同性学生名单,并统计同名人数
selectSname,count(*)fromStudentgroupbySnamehaving
count(*)>
1;
31、1981年出生的学生名单(注:
Student表中Sage列的类型是datetime)
selectSname,
CONVERT(char(11),DATEPART(year,Sage))asage
fromstudent
where
CONVERT(char(11),DATEPART(year,Sage))='
1981'
32、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
SelectC#,Avg(score)fromSCgroupbyC#orderbyAvg(score),C#DESC;
33、查询平均成绩大于85的所有学生的学号、姓名和平均成绩
selectSname,SC.S#,avg(score)
whereStudent.S#=SC.S#groupbySC.S#,Snamehaving
avg(score)>
85;
34、查询课程名称为“数据库”,且分数低于60的学生姓名和分数
SelectSname,isnull(score,0)
fromStudent,SC,Course
whereSC.S#=Student.S#andSC.C#=Course.C#and
Course.Cname='
数据库'
andscore=70ANDSC.S#=student.S#;
37、查询不及格的课程,并按课程号从大到小排列
selectc#fromscwherescore80andC#='
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、查询不同课程成绩相同的学生的学号、课程号、学生成绩
selectdistinct
A.S#,B.scorefromSCA
SCBwhereA.Score=B.ScoreandA.C#B.C#;
43、查询每门功成绩最好的前两名
SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数
WHEREscoreIN(SELECTTOP2score
44、统计每门课程的学生选修人数(超过10人的课程才统计)。
要求输出课程号和选修人数,查询结果按人数降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列
select
C#as课程号,count(*)as人数
from
sc
group
by
C#
order
count(*)desc,c#
45、检索至少选修两门课程的学生学号
S#
s#
having
count(*)
>
=
2
46、查询全部学生都选修的课程的课程号和课程名
C#,Cname
Course
C#
in
(select
c#
from
scgroup
c#)
47、查询没学过“叶平”老师讲授的任一门课程的学生姓名
selectSnamefromStudentwhereS#notin(selectS#fromCourse,Teacher,SCwhereCourse.T#=Teacher.T#andSC.C#=course.C#andTname='
48、查询两门以上不及格课程的同学的学号及其平均成绩
selectS#,avg(isnull(score,0))fromSCwhereS#in(selectS#fromSCwherescore2)groupbyS#;
49、检索“004”课程分数小于60,按分数降序排列的同学学号
selectS#fromSCwhereC#='
andscore
问题描述:
本题用到下面三个关系表:
CARD
借书卡。
CNO卡号,NAME
姓名,CLASS班级
BOOKS
图书。
BNO书号,BNAME书名,AUTHOR作者,PRICE单价,QUANTITY库存册数
BORROW
借书记录。
CNO借书卡号,BNO书号,RDATE还书日期
备注:
限定每人每种书只能借一本;
库存册数随借书、还书而改变。
要求实现如下15个处理:
1.写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束。
2.找出借书超过5本的读者,输出借书卡号及所借图书册数。
3.查询借阅了"
水浒"
一书的读者,输出姓名及班级。
4.查询过期未还图书,输出借阅者(卡号)、书号及还书日期。
5.查询书名包括"
网络"
关键词的图书,输出书号、书名、作者。
6.查询现有图书中价格最高的图书,输出书名及作者。
7.查询当前借了"
计算方法"
但没有借"
计算方法习题集"
的读者,输出其借书卡号,并按卡号降序排序输出。
8.将"
C01"
班同学所借图书的还期都延长一周。
9.从BOOKS表中删除当前无人借阅的图书记录。
10.如果经常按书名查询图书信息,请建立合适的索引。
11.在BORROW表上建立一个触发器,完成如下功能:
如果读者借阅的书名是"
数据库技术及应用"
,就将该读者的借阅记录保存在BORROW_SAVE表中(注ORROW_SAVE表结构同BORROW表)。
12.建立一个视图,显示"
力01"
班学生的借书信息(只要求显示姓名和书名)。
13.查询当前同时借有"
和"
组合数学"
两本书的读者,输出其借书卡号,并按卡号升序排序输出。
14.假定在建BOOKS表时没有定义主码,写出为BOOKS表追加定义主码的语句。
15.对CARD表做如下修改:
a.将NAME最大列宽增加到10个字符(假定原为6个字符)。
b.为该表增加1列NAME(系名),可变长,最大20个字符。
1.写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束
--实现代码:
CREATETABLEBORROW(
CNOintFOREIGNKEYREFERENCESCARD(CNO),
BNOintFOREIGNKEYREFERENCESBOOKS(BNO),
RDATEdatetime,
PRIMARYKEY(CNO,BNO))
2.找出借书超过5本的读者,输出借书卡号及所借图书册数
SELECTCNO,借图书册数=COUNT(*)
FROMBORROW
GROUPBYCNO
HAVINGCOUNT(*)>
5
3.查询借阅了"
一书的读者,输出姓名及班级
SELECT*FROMCARDc
WHEREEXISTS(
SELECT*FROMBORROWa,BOOKSb
WHEREa.BNO=b.BNO
AND
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- sql 试题 经典