zoukankan      html  css  js  c++  java
  • oracle 复杂的查找用法

    【第一题】: 找到员工表中工资最高的前三名,要求按如下格式输出(第一步部分);以及oracle查询结果指定分页显示的方法(第二部分)。

        ——涉及Top-N分析问题。
        一般不在子查询中使用order by, 但在Top-N分析问题中,必须使用order by

        想将现有的表进行分页。1-4第一页,5-8第二页……

    参考内容:

    行号rownum(伪列)需要注意的问题:
    1. rownum永远按照默认的顺序生成。
    SQL> select rownum, empno, ename, sal from emp order by sal desc
    ——发现行号是跟着行走的。查询结果顺序变了,行号依然固定在原来的行上。行号始终使用默认顺序。

    2.rownum只能使用<, <=符号,不能使用>,>=符号。

    原因:与行号生成的机制有关:Oracle中的行号永远从1开始——取了1才能取2,取了2才能取3,<=8可以是因为1234567挨着取到,而>=5不行,因为没有1234,不能直接取5。

    第一部分:输出图片的效果;
    SQL> select rownum, empno, ename, sal 
        from (select * 
            from emp 
            order by sal desc) 
        where rownum <=3
    
    第二部分,对查询的内容进行分页显示:
    1-4为一页;
    select rownum, empno, ename, sal
    from (select * from emp 
        order by sal desc)
    where rownum<=4 and rownum>=1
    /
    5-8为一页
    select  *
     from (select rownum r, empno, ename, sal
        from (select * from emp
                order by sal desc)
        where rownum<=8)
     where r >= 5
    
    关键是>=5 的获取问题,是不能直接写rownum>=5的。但是这条SQL语句查询的结果是一个新的“集合”,
    该集合中有一列是专门表示行号,可以假想这列不再是伪列,而是该集合中专门用来表示行号的列。
    所以,可以给该列取一个别名r,并把该查询语句整体作为子查询,放到另外一条SQL语句的from后。

    【第二题】找到员工表中薪水大于本部门平均薪水的员工

    采用两种方法:

    第一种:一般子查询,使用自连接(多表查询的一种特殊情况)

        与第一题一样,别名的特殊用法;可以从子查询中带出来,当作一个元素来使用。

        一般子查询的的执行顺序:先执行子查询(内查询),再执行主查询(外查询),相关子查询除外

    第二种:使用相关子查询()

        概念:将主查询的某个值,当作参数传递给子查询。

     1 一.一般子查询
     2 1  select empno, e.deptno, ename, sal , d.davg
     3  2  from emp e, (select deptno, avg(sal) davg
     4  3             from emp
     5  4             group by deptno) d
     6  5 where e.deptno = d.deptno and e.sal > d.davg
     7 
     8 
     9 二.相关子查询
    10   select empno, e.deptno, ename, sal , (select avg(sal) from emp where deptno = e.deptno group by deptno) as "avg"
    11   from emp e
    12   where sal>(select avg(sal) from emp
    13           where deptno = e.deptno)

    【第三题】统计每年入职的员工个数:以下图的格式展现:已知员工的入职年份是---1980,1981, 1982,1987;

    提示:该练习只考察函数的应用,注意调用关系。

    ——decode():第一个参数:待判断的值,条件,结果,条件,结果……最后是else的情况。

     1 以图中的格式输出
     2 select count(*) Total,
     3 sum(decode(to_char(hiredate, 'yyyy'), '1981', 1, 0)) "1981",
     4             sum(decode(to_char(hiredate, 'yyyy'), '1980', 1, 0)) "1980",
     5             sum(decode(to_char(hiredate, 'yyyy'), '1982', 1, 0)) "1982",
     6             sum(decode(to_char(hiredate, 'yyyy'), '1987', 1, 0)) "1987"
     7         from emp;
     8 
     9 
    10 
    11 
    12  如忽略输出格式:(即不是图中的输出格式:)
    13  
    14  select to_char(hiredate ,'yyyy')  as "年份", count(*) as "人数"
    15      from emp
    16      group by to_char(hiredate ,'yyyy')
  • 相关阅读:
    ros 录制
    shell 截取字符串
    Linux 关机
    shell获取字符串长度
    ubuntu14.04 设置开机自启动脚本
    获取本机ip的shell脚本
    shell 杀掉指定进程的服务
    html 绘制矩形轨迹,选中区域
    shell模拟ctrl c停止
    shell 字符串提取数字
  • 原文地址:https://www.cnblogs.com/yyx1-1/p/5887067.html
Copyright © 2011-2022 走看看