本文是在Cat Qi的原贴的基础之上,经本人逐题分别在MySql数据库中实现的笔记,持续更新...

参考原贴:http://www.cnblogs.com/qixuejia/p/3637735.html


01 表结构

  Student(Sno,Sname,Sage,Ssex)    学生表 
  Course(Cno,Cname,Tno)       课程表 
  SC(Sno,Cno,score)          成绩表 
  Teacher(Tno,Tname)        教师表


02 建表及插入测试数据

  (1) 建表:

 DROP TABLE IF EXISTS student ;
DROP TABLE IF EXISTS course ;
DROP TABLE IF EXISTS sc ;
DROP TABLE IF EXISTS teacher ; CREATE TABLE Student
(
Sno int,
Sname varchar(32),
Sage int,
Ssex varchar(8)
)ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; CREATE TABLE Course
(
Cno INT,
Cname varchar(32),
Tno INT
)ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; CREATE TABLE Sc
(
Sno INT,
Cno INT,
score INT
)ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; CREATE TABLE Teacher
(
Tno INT,
Tname varchar(16)
)ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

  【注】MySQL数据库建表时需要添加“ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci”命令,否则中文会发生乱码。

  (2) 插入测试数据:

  insert into Student select 1,'刘一',18,'男' union all
select 2,'钱二',19,'女' union all
select 3,'张三',17,'男' union all
select 4,'李四',18,'女' union all
select 5,'王五',17,'男' union all
select 6,'赵六',19,'女' insert into Teacher select 1,'叶平' union all
select 2,'贺高' union all
select 3,'杨艳' union all
select 4,'周磊'; insert into Course select 1,'语文',1 union all
select 2,'数学',2 union all
select 3,'英语',3 union all
select 4,'物理',4; insert into SC
select 1,1,56 union all
select 1,2,78 union all
select 1,3,67 union all
select 1,4,58 union all
select 2,1,79 union all
select 2,2,81 union all
select 2,3,92 union all
select 2,4,68 union all
select 3,1,91 union all
select 3,2,47 union all
select 3,3,88 union all
select 3,4,56 union all
select 4,2,88 union all
select 4,3,90 union all
select 4,4,93 union all
select 5,1,46 union all
select 5,3,78 union all
select 5,4,53 union all
select 6,1,35 union all
select 6,2,68 union all
select 6,4,71;

03 问题及实现代码

  (1)查询“1”课程比“2”课程成绩高的所有学生的学号;

select a.sno from
(select sno,score from sc where cno=1) a,
(select sno,score from sc where cno=2) b
where a.sno=b.sno and a.score>b.score;

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

 select Sno,AVG(Score) as AvgScore
from SC
group by Sno
having AVG(Score)>60

  (3)查询所有同学的学号、姓名、选课数、总成绩;

 select student.sno,student.sname,count(sc.cno),sum(sc.score) from
student left outer join sc
on student.sno = sc.sno
group by student.sno
order by student.sno;

  (4)查询姓“李”的老师的个数;

 select count(distinct tname) as count
from teacher
where tname like '李%';

  (5)查询没学过“叶平”老师课的同学的学号、姓名;

 select s.sno,s.sname
from student s
where s.sno not in
(
select distinct(sc.sno) from sc ,course c,teacher t
where sc.cno = c.cno and c.tno = t.tno and t.tname = '叶平'
)

  (6)查询学过“1”并且也学过编号“2”课程的同学的学号、姓名;

 select s.sno,s.sname from
student s,
(select sno from sc where cno=1) a,
(select sno from sc where cno=2) b
where s.sno = a.sno and a.sno = b.sno;

  方法二 用exist函数

 select s.Sno,s.Sname
from Student s,SC sc
where s.Sno=sc.Sno and sc.Cno=1 and exists
(
select * from SC sc2 where sc.Sno=sc2.Sno and sc2.Cno=2
)

  (7)查询学过“叶平”老师所教的所有课的同学的学号、姓名;

 select s.sno,s.sname
from student s,teacher t,
course c left outer join sc
on c.cno = sc.cno
where t.tname="叶平" and t.tno = c.cno and s.sno = sc.sno ;

  或者:

 select s.sno,s.sname
from student s
where s.sno in
(
select sc.sno
from sc,course c,teacher t
where c.cno=sc.cno and c.tno=t.tno and t.tname ="叶平"
group by sc.sno
having count(sc.cno)=
(
select count(c1.cno)
from course c1,teacher t1
where c1.tno=t1.tno and t1,tname ="叶平"
)
);

  (8)查询课程编号“2”的成绩比课程编号“1”课程低的所有同学的学号、姓名;

 select s.sno,s.sname
from student s
where s.sno in
(
select a.sno from
(select sno,score from sc where cno=2) a,
(select sno,score from sc where cno=1) b
where a.sno = b.sno and a.score < b.score
);

  (9)查询有课程成绩小于60分的同学的学号、姓名;

select s.sno,s.sname
from student s,sc
where sc.score<60 and s.sno=sc.sno
group by s.sno;

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

 select s.sno,s.sname
from student s
where s.sno not in
(
select sc.sno from sc
group by sc.sno
having count(distinct sc.cno)=
(
select count(distinct c.cno) from course c
)
);

  (11)查询至少有一门课与学号为“1”的同学所学相同的同学的学号和姓名;

 select distinct(s.sno),s.sname
from student s,sc
where s.sno=sc.sno and sc.cno in
(
select distinct(cno) from sc where sno=1
);

  (12)查询至少学过学号为“1”同学所有一门课的其他同学学号和姓名;

 select distinct(s.sno),s.sname
from student s,sc
where s.sno=sc.sno and s.sno != 1 and sc.cno in
(
select distinct(cno) from sc where sno=1
);

  (13)把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;

 update sc set score =
(
select avg(sc1.score) from sc sc1,course c,teacher t
where sc1.cno = c.cno and c.tno = t.tno and t.tname="叶平"
)
where cno in
(
select cno from course c,teacher t
where c.tno = t.tno and t.tname="叶平"
);

  (14)查询和“2”号的同学学习的课程完全相同的其他同学学号和姓名;

 select s.sno,s.sname
from student s
where s.sno != 2 and s.sno in
(
select distinct(sno) from sc
where cno in (select cno from sc where sno=2)
group by sno
having count(distinct cno)=
(
select count(distinct cno) from sc where sno=2
)
);

  (15)删除学习“叶平”老师课的SC表记录;

 delete from sc where cno in
(
select c.cno from course c,teacher t
where c.tno = t.tno and t.tname="叶平"
);

  (16)向SC表中插入一些记录,这些记录要求符合以下条件:①没有上过编号“2”课程的同学学号作为学号;②将“2”号课程的平均成绩作为其成绩;

 insert into sc
select s.sno,2,(select avg(score) from sc where cno=2)
from student s
where s.sno not in (select distinct(sno) from sc where cno=2);

  (17)按平均成绩从低到高显示所有学生的“语文”、“数学”、“英语”三门的课程成绩,按如下形式显示: 学生ID,语文,数学,英语,有效课程数,有效平均分; 【此处已补回15题中被删除的数据】

 select sc0.sno as "学生ID",
(select score from sc where sno=sc0.sno and cno =1) as "语文" ,
(select score from sc where sno=sc0.sno and cno =2) as "数学" ,
(select score from sc where sno=sc0.sno and cno =3) as "英语" ,
count(sc0.cno) as "有效课程数",
avg(sc0.score) as "有效平均分"
from sc sc0
group by sc0.sno
order by avg(sc0.score);

  (18)查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分;

 select cno as "课程ID",max(score) as "最高分",min(score) as "最低分"
from sc
group by cno;

  (19)按各科平均成绩从低到高和及格率的百分数从高到低顺序;

 select sc.cno as "课程ID",
c.cname as "课程名称",
avg(sc.score) as "平均分",
100*sum(case when sc.score >= 60 then 1 else 0 end)/count(sc.score) as "Percent(%)"
from sc ,course c
where sc.cno = c.cno
group by sc.cno
order by avg(sc.score) desc ;

  (20)查询如下课程平均成绩和及格率的百分数(备注:需要在1行内显示): 企业管理(2),OO&UML (3),数据库(4)

 select
sum(case when cno=2 then score else 0 end)/sum(case when cno=2 then 1 else 0 end) as "企业管理平均成绩",
100*sum(case when cno=2 and score >= 60 then 1 else 0 end)/sum(case when cno=2 then 1 else 0 end) as "企业管理及格率(%)",
sum(case when cno=3 then score else 0 end)/sum(case when cno=3 then 1 else 0 end) as "OO&UML平均成绩",
100*sum(case when cno=3 and score >= 60 then 1 else 0 end)/sum(case when cno=3 then 1 else 0 end) as "OO&UML及格率(%)",
sum(case when cno=4 then score else 0 end)/sum(case when cno=4 then 1 else 0 end) as "数据库平均成绩",
100*sum(case when cno=4 and score >= 60 then 1 else 0 end)/sum(case when cno=4 then 1 else 0 end) as "数据库及格率(%)"
from sc;

  (21)查询不同老师所教不同课程平均分从高到低显示; 

 select t.tname as "老师姓名",
c.cname as "课程名称",
avg(sc.score) as "平均分"
from sc,teacher t,course c
where t.tno=c.tno and c.cno=sc.cno
group by t.tno
order by avg(sc.score) desc;

  (22)查询如下课程成绩第 3 名到第 6 名的学生成绩单:企业管理(1),马克思(2),UML (3),数据库(4)  

 select distinct
SC.Sno As "学生学号",
Student.Sname as "学生姓名" ,
T1.score as "企业管理",
T2.score as "马克思",
T3.score as "UML",
T4.score as "数据库",
ifnull(T1.score,0) + ifnull(T2.score,0) + ifnull(T3.score,0) + ifnull(T4.score,0) as "总分"
from Student,SC left join SC as T1
on SC.Sno = T1.Sno and T1.Cno = 1
left join SC as T2
on SC.Sno = T2.Sno and T2.Cno = 2
left join SC as T3
on SC.Sno = T3.Sno and T3.Cno = 3
left join SC as T4
on SC.Sno = T4.Sno and T4.Cno = 4
where student.Sno=SC.Sno
order by ifnull(T1.score,0) + ifnull(T2.score,0) + ifnull(T3.score,0) + ifnull(T4.score,0) desc ;

  

SQL面试笔试经典题(Part 1)的更多相关文章

  1. SQL面试笔试经典题(Part 2)

    本文是在Cat Qi的原贴的基础之上,经本人逐题分别在MySql数据库中实现的笔记. 参考原贴:http://www.cnblogs.com/qixuejia/p/3637735.html 01 问题 ...

  2. JAVA面试/笔试经典题

    1.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? 对于short s1 = 1; s1 = s1 + 1; 由于s1+1运算时 ...

  3. 《PHP面试笔试真题库》——PHP面试的好帮手

    你好,是我琉忆. 一个文艺的PHP开发工程师. 很荣幸能够在这里带来我的第一本新书--<PHP程序员面试笔试真题库>. 一.创作过程 <PHP 程序员面试笔试真题库>是我的第三 ...

  4. 《PHP程序员面试笔试真题解析》——新书上线

    你好,是我--琉忆.很高兴可以跟你分享我的新书. 很高兴,在出版了PHP程序员面试笔试宝典后迎来了我的第二本书出版--<PHP程序员面试笔试真题解析>. 如果你是一个热爱PHP的程序员,刚 ...

  5. BAT面试笔试33题:JavaList、Java Map等经典面试题!答案汇总!

    JavaList面试题汇总 1.List集合:ArrayList.LinkedList.Vector等. 2.Vector是List接口下线程安全的集合. 3.List是有序的. 4.ArrayLis ...

  6. unity,C#,游戏面试笔试真题

    最开始的两家公司笔试面试题目 一家公司是学校聘请研究教育方面VR课件的公司,面试没几天,就收到了面试通过的消息,后面因为通过了另一家游戏公司而拒绝了. 另一家公司是一家游戏外企,在春熙路,当时笔试还可 ...

  7. sql练习题及经典题

    https://blog.csdn.net/mrbcy/article/details/68965271 经典例题 19.查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录. S ...

  8. 面试&笔试常见题,你了解多少?

    HTML:1.  什么是语义化的HTML?有何意义?为什么要做到语义化?(高频率考题)2.  行内元素和块元素分别有哪些?(高频率)3.  严格模式与混杂模式的区分?如何触发这两种模式?(高频率)4. ...

  9. 搜狗面试的经典题(C++map按值排序,class struct的差别)

    一:起因 (1)java  Map排序(key,value).请看还有一篇博客 java Map排序 (2)c++ map排序(key,value),能够对c++ map和java Map进行对照:之 ...

随机推荐

  1. Android中手机录屏并转换GIF的两种方式

    之前在博文中为了更好的给大家演示APP的实现效果,本人了解学习了几种给手机录屏的方法,今天就给大家介绍两种我个人用的比较舒服的两种方法: (1)配置adb环境后,使用cmd命令将手机界面操作演示存为视 ...

  2. WCF学习之旅—第三个示例之四(三十)

           上接WCF学习之旅—第三个示例之一(二十七)               WCF学习之旅—第三个示例之二(二十八)              WCF学习之旅—第三个示例之三(二十九)   ...

  3. [APUE]标准IO库(上)

    一.流和FILE对象 系统IO都是针对文件描述符,当打开一个文件时,即返回一个文件描述符,然后用该文件描述符来进行下面的操作,而对于标准IO库,它们的操作则是围绕流(stream)进行的. 当打开一个 ...

  4. IE8/9 本地预览上传图片

    本地预览的意思是,在选择图片之后先不上传到服务器,而是由一个<img>标签来预览本地的图片,非 IE8/9 浏览器可以从<input type="file"/&g ...

  5. [C#] C# 知识回顾 - 序列化

    C# 知识回顾 -  序列化 [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902005.html 目录 序列化的含义 通过序列化保存对象数据 众 ...

  6. wordpress优化之结合prism.js为编辑器自定义按钮转化代码

    原文链接 http://ymblog.net/2016/07/24/wordpress-prism/ 继昨天花了一天一夜的时间匆匆写了主题Jiameil3.0之后,心中一直在想着优化加速,体验更好,插 ...

  7. c# 字符串连接使用“+”和string.format格式化两种方式

    参考文章:http://www.liangshunet.com/ca/201303/218815742.htm 字符串之间的连接常用的两种是:“+”连接.string.format格式化连接.Stri ...

  8. 【深入Java虚拟机】之四:类加载机制

    类加载过程     类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括:加载.验证.准备.解析.初始化.使用和卸载七个阶段.它们开始的顺序如下图所示: 其中类加载的过程包括了加载.验 ...

  9. bzoj3208--记忆化搜索

    题目大意: 花花山峰峦起伏,峰顶常年被雪,Memphis打算帮花花山风景区的人员开发一个滑雪项目.    我们可以把风景区看作一个n*n的地图,每个点有它的初始高度,滑雪只能从高处往低处滑[严格大于] ...

  10. 装饰者模式 Decoration

    1.什么是装饰者模式 动态给对象增加功能,从一个对象的外部来给对象添加功能,相当于改变了对象的外观,比用继承的方式更加的灵活.当使用装饰后,从外部系统的角度看,就不再是原来的那个对象了,而是使用一系列 ...