`
53873039oycg
  • 浏览: 837172 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

Oracle分组排序后取前百分之N(每个分组)

阅读更多

    

 

select empno, ename, deptno, sale
  from (select empno,
               ename,
               sale,
               deptno,
               row_number() over(partition by deptno order by sale desc nulls last) as r_num,
               count(*) over(partition by deptno) as n_rows
          from emp)
 where r_num <= round(n_rows * &n / 100)
 order by deptno, sale desc;

    参考了博客https://community.oracle.com/thread/2539806?tstart=0,本人抛砖引玉,欢迎提出更好的方法,如有错误也请指出。谢谢

 

    全文完

 

0
0
分享到:
评论

相关推荐

    Oracle分析函数详解.doc

    在这个例子中,`SUM(sal) OVER (ORDER BY ename)`表示对每个部门的员工按照姓名升序排序后,计算工资的连续求和。这意味着每行的连续求和是之前所有行的工资总和。 分析函数的强大之处在于它们能够在单个SQL查询中...

    Oracle基础查询关联查询练习题.docx

    第六个练习题是查询职员表中员工号、姓名、工资,以及工资提高百分之 20%后的结果。该查询使用了 arithmetic 运算符来计算工资提高后的结果。 知识点:arithmetic 运算符的使用、基础查询的写法 7. 基础查询 第七...

    oracle10g之统计与分析函数

    - `ORDER BY`/`ORDER SIBLINGS BY`:在每个分组内进行排序。 - `ROWS|RANGE BETWEEN () AND ()`(Windowing Clause):定义一个窗口,可以是基于物理行的`ROWS`或基于逻辑位移的`RANGE`,并指明窗口的边界,如`...

    ORACLE 分析函数大全

    例如,`OVER (ORDER BY salary)`会按照薪水对数据进行排序并进行计算,而`OVER (PARTITION BY deptno)`则会在每个部门内部独立进行计算。 分析函数的一个典型例子是`AVG()`,它可以计算数据窗口内的平均值。在提供...

    Oracle分析函数详述

    Oracle还提供了许多其他分析函数,如ROW_NUMBER()(为每个分组的行分配一个唯一的行号),DENSE_RANK()(类似RANK(),但去除相同的排名间隙),LEAD()和LAG()(获取当前行的前后行数据),以及PERCENT_RANK()和CUME_...

    oracle 分析函数

    RANK()函数在每个分组内根据指定的排序标准分配唯一的排名。如果有两个或更多的行具有相同的值,它们将被赋予相同的排名,然后下一个排名会跳过相应数量。在第二个示例中,我们想要找出每个班级的第一名学生。由于...

    oracle 的几个分析函数

    这个数字从1开始递增,对于每个新的分组或排序顺序,数字会重新开始。例如,以下SQL语句将返回每个部门员工的编号: ```sql SELECT department_id, employee_name, ROW_NUMBER() OVER (PARTITION BY department_id ...

    Oracle分析函数参考手册

    在提供的示例中,`AVG(salary) OVER (PARTITION BY manager_id ORDER BY hire_date ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING)` 计算了每个经理手下员工的移动平均工资,这个平均值基于当前员工及其前一个和后一个...

    oracle分析函数

    - **Top/Bottom N、First/Last**:这些函数允许你选择数据集中的前N行或后N行,或者找出每个组的第一个或最后一个值。 - **NTILE**:将结果集的行划分为指定数量的桶或组,每个桶内的行数尽可能相等。 4. **窗口...

    oracle分析函数.doc

    - **Top/Bottom N, First/Last, NTile**:这些函数用于选择数据集的顶部或底部N行,或者获取每个组的第一行或最后一行,NTILE()则将数据分成N个桶或组。 - **窗口函数**:允许在特定窗口内应用函数,例如,计算...

    Oracle10gR2分析函数.pdf

    - **PARTITION BY**:用于分组数据,每个分组独立计算。 - **ORDER BY**:用于定义窗口内的行顺序。 - **ROWS 或 RANGE**:用于指定窗口的范围。 #### 三、常见分析函数及用法 1. **累计函数** - **SUM()**:...

    Oracle分析函数[汇编].pdf

    - `RANK`:为每个分组内的行赋予唯一的顺序号。 - `DENSE_RANK`:与RANK相似,但如果有相同值,不会跳过顺序号。 - `FIRST_VALUE` 和 `LAST_VALUE`:返回组中指定列的第一个和最后一个值。 - `LAG` 和 `LEAD`:...

    SQL开窗函数.zipSQL开窗函数.zipSQL开窗函数.zip

    - **NTILE()**:将数据分割成N个桶或组,每个组包含大致相同数量的行。 3. **应用示例** - **排名**:找出每个部门销售额最高的员工,使用`ROW_NUMBER() OVER(PARTITION BY department ORDER BY sales DESC)`。 ...

    SQL最佳实践

    但是,如果每次查询都使用实际值代替参数,则每个查询都需要重新解析。使用绑定变量可以让多个查询共享同一个执行计划,从而节省资源。 ##### INSERT INTO 在执行大量插入操作时,应该考虑一次性插入多行数据而...

    分析函数使用.pdf

    假设我们需要列出每个部门的薪资总和,并计算每个部门薪资总和占公司总薪资的比例。按照传统的SQL方法,这可能需要先创建一个视图来存储公司总薪资,然后再进行计算。而在使用分析函数的情况下,则可以一步到位地...

    SQL开窗函数的具体实现详解

    这使得处理复杂的排序、分组和计算变得更加便捷。在2003年的ISO SQL标准中引入了开窗函数,随后被MSSQL Server、Oracle、DB2等主流数据库系统支持,但遗憾的是,MySQL目前还不支持。 开窗函数的核心在于定义一个...

    测试培训教材

    测试人员每时每刻都在度量别人的工作成果,而测试人员的工作成果又由谁来度量呢?度量的标准和依据是什么呢?软件测试的度量是测试管理必须仔细思考的问题。缺乏尺度会让测试失去平衡,缺乏标准会让测试工作难以衡量...

Global site tag (gtag.js) - Google Analytics