Oracle常见的面试题四(10级学员 庞丽整理)

转载 2012年03月22日 20:54:48

Oracle常见的面试题:

题目:现有STUDENT(学生),COURSE(课程),SC(成绩)表,完成以下需求。(建表语句在emp.sql中,综合考察)

(1)       查询选修课程为web的学员学号和姓名

select s.sid,s.name from student s inner join sc on(s.sid=sc.sid)inner join course c on

(c.cid=sc.cid) where c.name='web';

         分析:课程与学生表没有直接联系,必须通过中间成绩表做2次连接。

2)查询课堂编号为2的学员姓名和单位

         select s.name,s.dept from student s inner join sc on (s.sid=sc.sid) where sc.cid=2;

3)查询不选修4号课程的学员姓名和单位

方法一:select name,dept from student where sid not in (select s.sid from student s left join sc on s.sid=sc.sid where cid=4);

方法二:select name,dept from student where not exists(select sid from sc where sc.sid=s.sid and cid=4);

分析:要点是先要查询出选修了4号课程的学员id,再从所有学员中排出这些id的学员。方法二效率较高。

4)求出所有学生的选修的所有课程

select * from student s inner join sc on s.sid=sc.sid inner join course c on sc.cid=c.cid order by s.sid;

分析:步骤1:查询出所有课程的数目

         Select count(*) from course;

步骤2:在成绩(sc)表,按学员id分组,看每组的个数,该个数等于步骤1课程总数的sid即为选修了所有课程的学员id

Select sid from sc group by sid having (count(*) =(select count(*) from course));

步骤3:再根据该sid查询学员的详细信息

Select s.name,s.dept from student s where sid in (select sid from sc group by sid having(count(*) = (select count(*) from course)));

5)查询选修课程超过3门的学员姓名和单位

         select * from student where sid in(select sid from(select sid,count(*) from (select s.* from student s inner join sc on s.sid=sc.sid inner join course c on sc.cid=c.cid order by s.sid) group by sid having count(*)>3 order by sid));

6)找出没有选修过TeacherLI 讲授课程的所有学生姓名

         select s.name from student s where sid not in (select sid from course c left join sc on(c.cid=sc.cid) where c.teacher='Teacher Li');

7)列出两门以上(含两门)不及格课程的学生姓名及其平均成绩

         select s.*,b.avgscore from student s,

(select sc.sid,avg(score) avgscore from sc,

       (select sid from sc where score <60 group by sid having(count(*)>=2))a

               where sc.sid=a.sid group by sc.sid)b

               where s.sid=b.sid;

分析:步骤1:查询所有两门以上不及格的学员id

Select sid from sc where score < 60 group by sid having(count(*)>=2);

步骤2:步骤1结果与真实表sc做连接,算平均成绩

Select sc.sid,svg(score)  avgscore  from sc,

         (select sid from sc where score <60 group by sid having(count(*)>=2))a

                   Where sc.sid=a.sid group by sc.sid;

步骤3:步骤2结果与真实表student做连接,查学员姓名

         Select s.*,b.avgscore from student s,

                   (select sid from sc where score<60 group by sid having(count(*)>=2))a

                            Where sc.sid=a.sid group by sc.sid;

8)列出既学过1号课程,又学过2号课程的所有学生姓名

         select s.name from student s inner join(select sc.sid from sc where sc.cid in(1,2) group by sid having(count(*)=2))a on(s.sid=a.sid);

分析:要点是不仅要学过1,2,号课程in(1,2),并且要求同时学过此两门课count(*)=2

9)列出1号课程成绩比2号课成绩高的所有学生的学号,姓名和1号课和2号课的成绩

         select s.sid,s.name,sc1.score,sc2.score from sc sc1,sc sc2,student s where s.sid=sc1.sid and sc1.sid=sc2.sid and sc1.cid =1 and sc2.cid=2 and sc1.score>sc2.score;

分析:要点在于自连接,把成绩表拆成两张表来看,sc1中只考虑1号课,sc2中只考虑2号课且sc1.score>sc2.score;最后再考虑将结果与student表连接查询姓名。

相关文章推荐

oracle面试题整理二(10级学员 乔宇整理)

Oracle面试题整理二(10级学员 乔宇整理) 1.查询工资最高的3 名员工信息 select * from (select * from emp order by sal desc) ...

WebService入门介绍及案例分析(10级学员 庞丽课堂总结)

WebService入门介绍及案例分析 一、WebService入门概述: 1、什么是WebService? WebService,就是基于Web的服务。它使用Web(HTTP)方式,接收和响应...

Spring第一个案例(10级学员 庞丽课堂总结)

Spring第一个案例(10级学员 庞丽课堂总结) 刚刚接触Spring,我们完成了第一个Spring的案例。下面我就要对Spring第一个案例源代码进行分析。 一、首先我们在Eclipse下新建...

Oracle常见面试题整理一(10级学员 郞志整理)

Oracle常见面试题整理 01  .查询各个部门的平均工资 SQL> select deptno,avg(nvl(sal,0)) from emp group by deptno; 02....

Oracle存储过程(10 级学员 庞丽课堂总结)

Oracle存储过程          今天我们学习了存储过程和存储函数也是一种PL/SQL块,是存入数据库的PL/SQL块,它和PL/SQL程序相比起来, 一、存储过程和它有很多优点,具体归纳一...

oracle其他数据对象 --- 视图(10级学员 韩晓爽课堂总结)

oracle其他数据对象 --- 视图 一 介绍: 1.什么是视图:     视图是从一个表或多个表中导出的虚表,它与常规表不同之处在于它并不存储数据,它只是在一个存储的查询中定义.视图同真实表...

oracle集合运算_10级 学员 马林 课堂总结

集合运算 10级 学员 马林 课堂总结 集合操作符 1. UNION/UNION ALL 并集 UNION运算符返回两个集合去掉重复元素后的所有记录 我们以查询姓名中含有A或者M的人的列...

ORCL数据字典(10级学员 张家玮整理)

ORCL数据字典  ORACLE数据字典是ORACLE数据库的重要组成部分,它提供了诸如数据库结构、数据库对象空间分配和数据库用户等等有关数据库的信息。本文试图从数据库管理系统的若干基本概念出发,具...

部分常见ORACLE面试题以及SQL注意事项(更新......)

部分常见ORACLE面试题以及SQL注意事项   一、表的创建: 一个通过单列外键联系起父表和子表的简单例子如下: CREATE TABLE parent(id INT NOT NULL, ...

部分常见ORACLE面试题以及SQL注意事项(转载)

部分常见ORACLE面试题以及SQL注意事项   一、表的创建: 一个通过单列外键联系起父表和子表的简单例子如下: CREATE TABLE parent(id INT NOT...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Oracle常见的面试题四(10级学员 庞丽整理)
举报原因:
原因补充:

(最多只允许输入30个字)