partition by 函数

工作中用到的sql

select
       t."ID",
       t."TITLE",
       t."SENDUSERID",
       t."SENDTIME",
       t."URL",
       t."USERID",
       t."TODOTYPE",
       t."MODELNAME",
       t."IMPORTANCE",
       t."SENDUSERNAME",
       t."SENDUSERDEPTNAME",
       t.DATAID,
       t.OPENFLAG,
       t.realuserid,
       t.status,
       t.donetime from
(select m."ID",
       m."TITLE",
       m."SENDUSERID",
       m."SENDTIME",
       m."URL",
       m."USERID",
       m."TODOTYPE",
       m."MODELNAME",
       m."IMPORTANCE",
       m."SENDUSERNAME",
       m."SENDUSERDEPTNAME",
       m.DATAID,
       m.OPENFLAG,
       m.realuserid,
       m.status,
       m.donetime , row_number() over(partition by m.DATAID,m.status,m.realuserid order by m."SENDTIME" desc) rn from (
select a."ID",
       a."TITLE",
       a."SENDUSERID",
       a."SENDTIME",
       a."URL",
       a."USERID",
       a."TODOTYPE",
       a."MODELNAME",
       a."IMPORTANCE",
       a."SENDUSERNAME",
       a."SENDUSERDEPTNAME",
       a.DATAID,
       b.OPENFLAG,
       b.userid as realuserid,
       b.status,
       b.donetime
  from TD_HORIZON_Info a, TD_HORIZON_User b
 where a.id = b.TODOID
    ) m )t
     where rn=1;

Parttion by 关键字是Oracle中分析性函数的一部分,它和聚合函数不同的地方在于它能够返回一个分组中的多条记录,聚合函数一般只有一条反映统计值的结果

  场景:查询出每个部门工资最低的员工编号【每个部门可能有两个最低的工资员工】

--row_number() 顺序排序
select row_number() over(partition by deptid order by salary) my_rank ,deptid,USERID,salary from tsaler;
--rank() (跳跃排序,如果有两个第一级别时,接下来是第三级别)
select rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler;
--dense_rank()(连续排序,如果有两个第一级别时,接下来是第二级)
select dense_rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler;
-------方案3解决方案
select * from (select rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler) where my_rank=1;
select * from (select dense_rank() over(partition by deptid order by salary) my_rank,deptid,USERID,salary from tsaler) where my_rank=1;
时间: 2024-12-05 14:28:40

partition by 函数的相关文章

OVER(PARTITION BY)函数用法

2010年10月26日 OVER(PARTITION BY)函数介绍 开窗函数               Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. 开窗函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化,举例如下:1:over后的写法:       over(order by salary) 按照salary排序进行累计,order by是个默认的开窗

oracle下的OVER(PARTITION BY)函数介绍

转自:http://www.cnblogs.com/lanzi/archive/2010/10/26/1861338.html OVER(PARTITION BY)函数介绍 开窗函数               Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. 开窗函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化,举例如下:1:over后的写法:      

获得供应商最近一次报价:OVER(PARTITION BY)函数用法的实际用法

利用rownumber ,关键字partition进行小范围分页 方法一: --所有供应商对该产品最近的一次报价with oa as(select a.SupplierId ,UnitPrice,ProductBaseId, detail.LastModified,detail.Id from Latent_Export.dbo.bjQuotationForm  a inner join  bjQuotationFormDetail detail  on detail.QuotationForm

【Oracle】OVER(PARTITION BY)函数用法

OVER(PARTITION BY)函数介绍 开窗函数               Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. 开窗函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化,举例如下:1:over后的写法:       over(order by salary) 按照salary排序进行累计,order by是个默认的开窗函数   over(pa

row_number() OVER(PARTITION BY)函数介绍 .

OVER(PARTITION BY)函数介绍 开窗函数               Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. 开窗函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化,举例如下:1:over后的写法:       over(order by salary) 按照salary排序进行累计,order by是个默认的开窗函数   over(pa

over partition by 函数

over(Partition by...) 一个超级牛皮的ORACLE特有函数. 天天都用ORACLE,用了快2年了.最近才接触到这个功能强大而灵活的函数.真实惭愧啊! oracle的分析函数over 及开窗函数 一:分析函数over Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是 对于每个组返回多行,而聚合函数对于每个组只返回一行. 下面通过几个例子来说明其应用. 1:统计某商店的营业额. date       sale 1       

OVER(PARTITION BY)函数介绍

开窗函数               Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行. 开窗函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化,举例如下:1:over后的写法:       over(order by salary) 按照salary排序进行累计,order by是个默认的开窗函数   over(partition by deptno)按照部门分

SQL Server数据库partition by 与ROW_NUMBER()函数使用详解[转]

关于SQL的partition by 字段的一些用法心得 先看例子: if object_id('TESTDB') is not null drop table TESTDB create table TESTDB(A varchar(8), B varchar(8)) insert into TESTDB select 'A1', 'B1' union all select 'A1', 'B2' union all select 'A1', 'B3' union all select 'A2'

over(partition by)开窗函数的使用

开窗函数是分析函数中的一种,开窗函数与聚合函数的区别是:开窗函数是用于计算基于组的某种聚合值且每个的组的聚合计算结果可以有多行,而聚合函数每个组的聚合计算结果只有一个.使用开窗函数可以在没有group by语句的情况下计算聚合值并将结果作为一个新字段输出.开窗函数还可以和其他函数结合使用,如row_number().rank().dense_rank().min().max().sum().first_value() .last_value().avg()等等,聚合函数与开窗函数结合使用可以提供