sql面试题经典.docx

上传人:b****5 文档编号:8168628 上传时间:2023-01-29 格式:DOCX 页数:40 大小:35.96KB
下载 相关 举报
sql面试题经典.docx_第1页
第1页 / 共40页
sql面试题经典.docx_第2页
第2页 / 共40页
sql面试题经典.docx_第3页
第3页 / 共40页
sql面试题经典.docx_第4页
第4页 / 共40页
sql面试题经典.docx_第5页
第5页 / 共40页
点击查看更多>>
下载资源
资源描述

sql面试题经典.docx

《sql面试题经典.docx》由会员分享,可在线阅读,更多相关《sql面试题经典.docx(40页珍藏版)》请在冰豆网上搜索。

sql面试题经典.docx

sql面试题经典

不错的sql面试题  

Student(S#,Sname,Sage,Ssex)学生表

Course(C#,Cname,T#)课程表

SC(S#,C#,score)成绩表

Teacher(T#,Tname)教师表

问题:

1、查询“001”课程比“002”课程成绩高的所有学生的学号;

  selecta.S#from(selects#,scorefromSCwhereC#='001')a,(selects#,score

  fromSCwhereC#='002')b

  wherea.score>b.scoreanda.s#=b.s#;

2、查询平均成绩大于60分的同学的学号和平均成绩;

  selectS#,avg(score)

  fromsc

  groupbyS#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,Teacherwhere  SC.C#=Course.C#andTeacher.T#=Course.T#andTeacher.Tname='叶平');

6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;

  selectStudent.S#,Student.SnamefromStudent,SCwhereStudent.S#=SC.S#andSC.C#='001'andexists(Select*fromSCasSC_2whereSC_2.S#=SC.S#andSC_2.C#='002');

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#='002')score2

  fromStudent,SCwhereStudent.S#=SC.S#andC#='001')S_2wherescore260);

10、查询没有学全所有课的同学的学号、姓名;

  selectStudent.S#,Student.Sname

  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#='001'THENscoreELSE0END)/SUM(CASEC#WHEN'001'THEN1ELSE0END)AS企业管理平均分

      ,100*SUM(CASEWHENC#='001'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHENC#='001'THEN1ELSE0END)AS企业管理及格百分数

      ,SUM(CASEWHENC#='002'THENscoreELSE0END)/SUM(CASEC#WHEN'002'THEN1ELSE0END)AS马克思平均分

      ,100*SUM(CASEWHENC#='002'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHENC#='002'THEN1ELSE0END)AS马克思及格百分数

      ,SUM(CASEWHENC#='003'THENscoreELSE0END)/SUM(CASEC#WHEN'003'THEN1ELSE0END)ASUML平均分

      ,100*SUM(CASEWHENC#='003'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHENC#='003'THEN1ELSE0END)ASUML及格百分数

      ,SUM(CASEWHENC#='004'THENscoreELSE0END)/SUM(CASEC#WHEN'004'THEN1ELSE0END)AS数据库平均分

      ,100*SUM(CASEWHENC#='004'ANDscore>=60THEN1ELSE0END)/SUM(CASEWHENC#='004'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#='001'

        LEFTJOINSCAST2

              ONSC.S#=T2.S#ANDT2.C#='002'

        LEFTJOINSCAST3

              ONSC.S#=T3.S#ANDT3.C#='003'

        LEFTJOINSCAST4

              ONSC.S#=T4.S#ANDT4.C#='004'

    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

        ISNULL(T1.score,0)+ISNULL(T2.score,0)+ISNULL(T3.score,0)+ISNULL(T4.score,0)

    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)平均成绩

        FROMSC

      GROUPBYS#

      )AST2

  ORDERBY平均成绩desc;

  

25、查询各科成绩前三名的记录:

(不考虑成绩并列情况)

    SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数

    FROMSCt1

    WHEREscoreIN(SELECTTOP3score

          FROMSC

          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)

  fromStudent,SC

  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#='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、查询不同课程成绩相同的学生的学号、课程号、学生成绩

  selectdistinct  A.S#,B.scorefromSCA  ,SCBwhereA.Score=B.ScoreandA.C#B.C#;

43、查询每门功成绩最好的前两名

  SELECTt1.S#as学生ID,t1.C#as课程ID,Scoreas分数

    FROMSCt1

    WHEREscoreIN(SELECTTOP2score

          FROMSC

          WHEREt1.C#=C#

        ORDERBYscoreDESC

          )

    ORDERBYt1.C#;

44、统计每门课程的学生选修人数(超过10人的课程才统计)。

要求输出课程号和选修人数,查询结果按人数降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列  

  select  C#as课程号,count(*)as人数

  from  sc  

  group  by  C#

  order  by  count(*)desc,c#  

45、检索至少选修两门课程的学生学号

  select  S#  

  from  sc  

  group  by  s#

  having  count(*)  >  =  2

46、查询全部学生都选修的课程的课程号和课程名

  select  C#,Cname  

  from  Course  

  where  C#  in  (select  c#  from  scgroup  by  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#='004'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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 表格模板 > 合同协议

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1