几个oracle练习题

Posted alohabill

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了几个oracle练习题相关的知识,希望对你有一定的参考价值。

--1.查询哪个部门的平均工资是最高的,列出部门编码、平均工资。  
select deptno,avg(sal) from emp group by deptno having avg(sal)=(select max(avg(sal)) from emp group by deptno);
--2.列出各个部门中工资最高的员工的信息:名字、部门号、工资。  
select emp.ename,emp.deptno,emp.sal
from emp,(select deptno t_dept,max(sal) t_maxsal from emp group by deptno) tab1
where emp.deptno=tab1.t_dept and emp.sal=tab1.t_maxsal;
--3.查询上级是“KING”的员工姓名(ename)和工资(sal)。  
select ename,sal from emp where mgr=(select empno from emp where ename=‘KING‘);
--4.查询部门所在地(loc)为“NEW YORK”的部门的员工的姓名(ename),部门名称(dname)和岗位名称(job)
select ename,deptno,job from emp where deptno=(select deptno from dept where loc=‘NEW YORK‘);
--5.查询工资比公司平均工资高的所有员工的员工号(empno), 姓名(ename)和工资(sal)。
select empno,ename,sal from emp where sal>(select avg(sal) from emp);
--6.查询姓名中包含字母“u”的员工在相同部门的员工的员工号(empno)和姓名(ename)。
select empno,ename from emp where deptno=(select deptno from emp where ename like ‘%U%‘);
--7.查询哪些员工的薪水比本部门的平均薪水低。  
select emp.*
from emp,(select deptno,avg(sal) avg_sal from emp group by deptno) tab
where emp.deptno=tab.deptno and emp.sal<tab.avg_sal;
--8.查询emp表前5条记录
select * from (select emp.*,rownum rn from emp ) tab1 where tab1.rn<=5;
--9.查询第3-5条记录,无需排序
select * from (select emp.*,rownum rn from emp ) tab1 where tab1.rn between 3 and 5;
--10.查询公司工资最高的三个人
select * from (
select tab1.*,rownum rn from (select emp.* from emp order by sal desc)tab1)tab2 where tab2.rn<=3;
--11.查询公司工资最低的五个人
select * from (
select tab1.*,rownum rn from (select emp.* from emp order by sal asc)tab1)tab2 where tab2.rn<=5;






























以上是关于几个oracle练习题的主要内容,如果未能解决你的问题,请参考以下文章

oracle语句练习

Oracle的一道练习题:假定有一个XSCJ数据库,其中有一个学生基本数据表XSB和一张专业表ZYB

Oracle 默认的几个登陆用户名和密码

Oracle数据库面试练习题

Oracle SQL部分练习题

Oracle练习题