<span style="font-size:18px;">最近精力比较有限,有些常用的东西就先记录下来。方便以后自己查阅和总结。</span>
一个哥们想要实现如下效果:
DEPTNO ENAME SAL TOP3 部门工资 排序
---------- ---------- ---------- ----------
20 KING 5000 1 8750 2
20 CLARK 2450 2 8750 2
20 MILLER 1300 3 8750 2
10 SCOTT 3000 1 8975 1
10 FORD 3000 2 8975 1
10 JONES 2975 3 8975 1
30 BLAKE 2850 1 5950 3
30 ALLEN 1600 2 5950 3
30 TURNER 1500 3 5950 3
从上图可以看出,他想要实现部门的总工资排名。这个就要用到我们常说的分析函数了。分析函数是什么,这里就不多说了。有兴趣的朋友,请自己查阅官方文档。
下面我们来实现上图的功能:
首先,第一步我们需要先求出每个部门的总工资,SQL如下:select deptno,
ename,
sal,
sum(sal) over(partition by deptno order by deptno) as sumsal
from emp
查询的结果集:
第二步,我们就要实现最终的功能,附上SQL:
select deptno,
ename,
sal,
sumsal,
row_number() over(partition by deptno order by sal) as "部门内排名",
dense_rank() over(order by sumsal) as "部门排名"
from (select deptno,
ename,
sal,
sum(sal) over(partition by deptno order by deptno) as sumsal
from emp)
结果集如下:
图片显示的效果,就是我们想要的最终结果。以后在附上相关分析函数的使用效果。今天就到这,上班了。。。。
版权声明:本文为博主原创文章,未经博主允许不得转载。
分享到:
相关推荐
还是以上述为例,当field1字段值相同时,dense_rank函数会连续分配序号,即后三条记录的序号分别为1、1、1,而第4条记录的序号将是2,保持序号的连续性,后面的记录依然依次递增。SQL语句如下: ```sql select ...
MS SQL 2005 中的排名函数包括 ROW_NUMBER、RANK、DENSE_RANK 和 NTILE,这四个函数可以有效地分析数据并提供排序值。下面将详细介绍每个函数的用法和示例。 一、ROW_NUMBER 函数 ROW_NUMBER 函数返回结果集分区...
通过以上介绍可以看出,ROW_NUMBER()、RANK() 和 DENSE_RANK() 是SQL Server中非常有用的窗口函数,可以帮助我们在查询结果中添加行号、排名或密集排名。这些函数在处理大型数据集时尤其有用,能够帮助我们更方便地...
ROW_NUMBER() OVER (PARTITION BY region_id ORDER BY customer_sales DESC) AS rank_in_region FROM user_order; ``` 这样,我们就可以在每个区域内找到销售额最高的客户,而不会因为其他区域的客户销售额相同...
### Oracle Row_Number 函数详解 #### 一、Row_Number 基础概念 在Oracle数据库中,`ROW_NUMBER()`函数是一种窗口函数,主要用于为查询结果中的每一行分配一个唯一的序列号。这一特性使得它在处理分组数据时非常...
在SQL Server 2005中,`ROW_NUMBER()`、`RANK()`和`DENSE_RANK()`是三种常用的排名函数,它们在处理大数据集时非常有用,尤其在数据分析和报表生成方面。这些函数都可以帮助我们根据指定的条件对数据进行排序并赋予...
在这篇文档中,我们将详细学习在Hive中如何进行分组取topN,以及如何使用row_number()、rank()和dense_rank()三种窗口函数进行数据排序和排名。 首先,Hive中的数据表创建和数据插入操作是数据查询和分析的前提。...
本文主要讲解SQL中的四大排名函数:ROW_NUMBER、RANK、DENSE_RANK以及NTILE,它们在数据分析和报表生成中起到关键作用。 1. ROW_NUMBER() ROW_NUMBER()函数用于为查询结果集中的每一行分配一个唯一的数字序列。这个...
此外,`ROW_NUMBER()`函数还有其他窗口函数,如`RANK()`和`DENSE_RANK()`,它们在某些场景下可能会提供更灵活的解决方案。但在这里,我们主要关注`ROW_NUMBER()`在分页中的应用。 总结起来,`ROW_NUMBER()`函数在...
`row_number()`, `rank()`, 和 `dense_rank()` 是三个重要的窗口函数,用于为查询结果集中的每一行分配唯一的序列号,常用于分组、排名或者实现分区排序。下面我们将详细探讨这三个函数的区别和用法。 1. `row_...
`rank()`和`dense_rank()`函数是`row_number()`的两个变体: - **rank()**:类似`row_number()`,但它在遇到相等的排序值时会产生跳跃。也就是说,如果有两个行在排序列上有相同的值,它们都会被赋予相同的排名,接...
在实际工作中,理解和掌握ROW_NUMBER()、RANK()和DENSE_RANK()的区别至关重要,能够帮助我们编写更高效、精确的SQL查询,从而优化数据处理和分析流程。通过阅读"The-Difference-Between-ROW-NUMBER-RANK-and-DENSE-R...
SQL Server 2005 中提供了四个排名函数,分别是 row_number、rank、dense_rank 和 ntile。这四个函数的主要功能是为查询结果生成一个序号,用于实现查询指定范围的记录或实现分页功能。 一、row_number 函数 row_...
SQL 获取顺序号的四种方法:IDENTITY、RANK、DENSE_RANK、ROW_NUMBER 在 SQL 中,获取顺序号是非常常见的操作。今天,我们将讨论四种获取顺序号的方法:IDENTITY、RANK、DENSE_RANK、ROW_NUMBER。每种方法都有其优...