你兼职

全国
中心思想

本文将围绕 身在职场的你够细心吗,oracle经典20道笔试题 来给读者提供优质内容

  列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
  
  1.列出薪金比“SMITH”多的所有员工。
  
  select * from emp
  
  where sal >(select sal from emp where ename=’SMITH’)
  
    2.列出至少有一个员工的所有部门。
  
  select dept.deptno,dept.dname
  
  from dept,emp
  
  where dept.deptno=emp.deptno
  
  3.列出所有员工的姓名及其直接上级的姓名。
  
  select yg.ename,sj.ename
  
  from emp yg,emp sj
  
  where yg.mgr=sj.empno
  
  4.列出受雇日期早于其直接上级的所有员工。
  
  select yg.ename,sj.ename
  
  from emp yg join emp sj on yg.mgr=sj.empno
  
  where yg.hiredate
  
  5.列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。
  
  select dept.deptno,dept.dname,emp.empno,emp.ename
  
  from dept left join emp
  
  on dept.deptno=emp.deptno
  
  6.列出所有“CLERK”(办事员)的姓名及其部门名称。
  
  select * from dept,emp
  
  where dept.deptno=emp.deptno
  
  and job=’CLERK’
  
  7.列出最低薪金大于1500的各种工作。
  
  select job from emp
  
  group by job
  
  having min(sal)>1500
  
  8.列出在部门名称为“SALES”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。
  
  方法一:
  
  select emp.ename
  
  from dept,emp
  
  where dept.deptno=emp.deptno
  
  and dname=’SALES’
  
  方法二:
  
  select * from emp
  
  where deptno=(select deptno from dept where dname=’SALES’)
  
  9.列出薪金高于公司平均薪金的所有员工。
  
  select * from emp
  
  where sal> (select avg(sal) from emp)
  
  对比:列出薪金高于本部门平均薪金的所有员工。
  
  方法一:
  
  select * from emp a
  
  where a.sal>(select avg(sal) from emp b where b.deptno=a.deptno)
  
  缺点:相关子查询,效率低。
  
  方法二:
  
  select empno,ename,sal from
  
  emp a,(select avg(sal) avg_sal from emp b where b.deptno=a.deptno) b
  
  where a.deptno=b.deptno
  
  and a.sal>b.avg_sal
  
  10.列出与“SCOTT”从事相同工作的所有员工。
  
  select * from emp
  
  where job=(select job from emp where ename=’SCOTT’)
  
  11.列出薪金等于部门30中员工的薪金的所有员工的姓名和薪金。
  
  select ename,sal from emp
  
  where sal=any(select sal from emp where deptno=30 )
  
  12.列出薪金高于在部门30工作的所有员工的薪金的员工姓名和薪金。
  
  方法一:
  
  select ename,sal from emp
  
  where sal>all(select sal from emp where deptno=30 )
  
  方法二:
  
  select ename,sal from emp
  
  where sal>(select max(sal) from emp where deptno=30 )
  
  13.列出在每个部门工作的员工数量、平均工资和平均服务期限。
  
  select deptno,avg(trunc((sysdate-hiredate)/365)) as year
  
  from emp
  
  group by deptno
  
  –参考:截断,取整函数
  
  select trunc(99.9) from dual;
  
  返回
  
  99
  
  14.列出所有员工的姓名、部门名称和工资。
  
  select d.dname,e.ename,e.sal
  
  from dept d,emp e
  
  where d.deptno=e.deptno
  
  说明:每个字段都加表前缀,效率要高些
  
  15.列出所有部门的详细信息和部门人数。
  
  select dept.deptno,dept.dname,count(*)
  
  from dept,emp
  
  where dept.deptno=emp.deptno
  
  group by dept.deptno,dept.dname
  
  16.列出各种工作的最低工资。
  
  select job,min(sal) from emp group by job
  
  17.列出各个部门的MANAGER(经理)的最低薪金。
  
  select deptno,min(sal) from emp where job=’MANAGER’ group by deptno
  
  18.列出所有员工的年工资,按年薪从低到高排序。
  
  select empno,ename,sal*12 as 年薪 from emp
  
  order by sal
  
  19. 列出各种工作工资前3名的员工
  
  select * from (
  
  select empno,ename,sal,job,
  
  dense_rank() over(partition by job order by sal desc) as 名次
  
  from emp ) a
  
  where a.名次<=2
  
  order by job;
  
  说明:用到了Oracle强大的“分区排名技术”,其中“dense_rank()”是Oracle的解析函数。
  
  20. 求各种工作工资最低的员工。
  
  方法一:
  
  select * from emp a
  
  where sal=(select min(sal) from emp b where b.job=a.job)
  
  方法二:
  
  select emp.*
  
  from emp a,( select job,min(sal) min_sal from emp group by job) b
  
  where a.job=b.job and a.sal=b.min_sal

猜你喜欢

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权, 不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件至 3168667431@qq.com举报,一经 查实,本站将立刻删除。