`
demitong
  • 浏览: 7006 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

PARTITION BY分组

阅读更多
最近看了PARTITION BY分组,感觉很高深,又不常用到,遂记录下来,留作日后装B(貌似子查询联合查询也能解决),或者懂的多了,再来回顾吧...

不多说了,直接贴研究好的代码

销售报表
  SELECT   b,   c,   d,SUM(d)   OVER(PARTITION   BY   b,c   ORDER   BY   d)   e   FROM   a  
  B C D E  
  02 01 2 2                     d=2,sum(d)=2  
  02 01 5 7                     d=5,sum(d)=7  
  02 01 23 30                   d=23,sum(d)=30  
  02 02 1 1                     c值不同,重新累计  
  02 02 12 13  
  02 03 2 2  
  02 03 5 7  
  02 04 3 3  
  02 05 4 4  
  02 06 6 6  
  02 07 7 7
ps:计算函数中的累积和,因为自己是英文盲...放一个简单示例方便以后看好了
年度销售报表
select ID,店铺名称,时间,月销售额度,SUM(月销售额度) over (PARTITION BY 店铺名称 ORDER BY 时间) from 销售额汇总表 where 时间 BETWEEN 2011 AND 2012

原帖:
http://blog.csdn.net/java_greenhand/article/details/6274015
============

另一种应用方式:
SELECT * FROM (SELECT row_number() OVER (PARTITION BY siteid ORDER BY bookid) as rownum, * FROM novel_bookchapterinfo) t WHERE t.rownum = 1
获取不重复的(图书出版社)地址?很有趣的写法
原帖:
http://www.cnblogs.com/aspnethot/archive/2010/03/02/1676245.html
分享到:
评论

相关推荐

    sqlserver巧用row_number和partition by分组取top数据

    分组取TOP数据是T-SQL中的常用查询, 如学生信息管理系统中取出每个学科前3名的学生。这种查询在SQL Server 2005之前,写起来很繁琐,需要用到临时表关联查询才能取到。SQL Server 2005后之后,引入了row_number()...

    T-SQL高级查询

    # partition by分组子句 可以完成对分组的数据进行增加排序,partition by可以与以上三个函数联合使用。 利用partition by按照班级名称分组,学生id排序 select s.id, s.name, cid, c.name, row_number() over...

    SQLServer中Partition By及row_number 函数使用详解

    partition by关键字是分析性函数的一部分,partition by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组,本文给大家介绍SQLServer中Partition By及row_number 函数使用详解,需要的朋友参考下

    详解partition by和group by对比

    1. group by是分组函数,partition by是分析函数(然后像sum()等是聚合函数); 2. 在执行顺序上, 以下是常用sql关键字的优先级 from > where > group by > having > order by 而partition by应用在以上关键字之后...

    【Oracle】LISTAGG函数的使用.pdf

    LISTAGG(合并字段, 连接符) WITHIN GROUP(ORDER BY 合并字段的排序) OVER(PARTITION BY 分组字段) 2. 作为聚合函数,类似于 sum()、count()、avg() 等函数,使用方法相似: LISTAGG(合并字段, 连接符) WITHIN ...

    SQL Server 2012 开窗函数

    废话不多说了,直接给大家贴代码了,具体代码如下所示: -- 开窗函数:在结果集的基础上进一步处理(聚合操作) ...-- Partition By 分组统计数量 -- 根据性别分组后,统计 SELECT COUNT(*) OVER ( PARTITION

    Oracle中分组后拼接分组字符串[文].pdf

    select No, Value, Name, rnFirst, lead(rnFirst) over(partition by No order by rnFirst) rnNext from (select a.No, a.Value, a.Name, row_number() over(order by a.No, a.Value desc) rnFirst from Test a) ...

    Oracle中分组后拼接分组字符串.pdf

    lead(rnFirst) over(partition by No order by rnFirst) rnNext from ( select a.No, a.Value, a.Name, row_number() over(order by a.No, a.Value desc) rnFirst from Test a ) tmpTable1 ) tmp...

    sql 分组内排序.txt

    case ROW_NUMBER() OVER(PARTITION BY TT.sheet_no ORDER BY TT.sheet_no 分组内排序用法

    对某一字段分组后,取出另一字段最大值的所有记录

    表:t_test -------------------------------------- id(int) cost(int) des Autoid(id) -------------------------------------- 1 10 aaaa 1 1 15 bbbb 2 1 20 cccc 3 2 80 aaaa 4 2 100 bbbb 5 ...

    大数据hive中窗口函数的一些常用函数

    窗口函数的基础语法为:<窗口函数> over (partition by <用于分组的列名> order by <用于排序的列名> <窗口范围>)。其中,partition by子句用于指定分组的列名,order by子句用于指定排序的列名,窗口范围指定了窗口...

    oracle分组查询

    oracle分组查询数据 select BFMBIGNAME,projectaddress,...from(select BFMBIGNAME,projectaddress,BFMSMALLNAME,row_number() over (partition by BFMBIGNAME order by REGISTERDATE) id from Projectinfo) where id;

    SQL语句分组获取记录的第一条数据的方法

    使用ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2) 先进行分组 注:根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的). sql语句为: select ...

    快速RFID分组协议

    In RFID systems, the grouping problem is to efficiently group all tags according to a given partition such that tags in the same group will have the same group ID. Unlike previous research on the ...

    分组排序选择需要一条

    sql 排序:row_number() over(partition by sjjl_id order by fksj desc,最优化的情况,里面放的有例子,大家可以参考

    oracle函数介绍(7) 非著名函数之分析函数.doc

    1、CUME_DIST() OVER([partition_clause] order_by_clause) 返回该行在分组序列中的相对位置,返回值介于0到1之间。注意哟,如果order by的列是desc,则该分组内最大的行返回列值1,如果order by为asc,则该分组内...

    oracle函数介绍(5) 分析函数简述.doc

    第五篇 分析函数简述 分析函数的语法结构比较复杂,但多数函数都具有相同的语法...Partition没啥说的,功能强大参数少,主要用于分组,可以理解成select中的group by。不过它跟select语句后跟的group by 子句并不冲突。

    Gbase 8s内置函数之窗口函数

    ROW_NUMBER() OVER (PARTITION BY f_deptid ORDER BY f_salary DESC) AS f_order, f_deptname, f_employeename, f_salary FROM (SELECT a.f_employeeid, a.f_deptid, b.f_deptname, a.f_...

Global site tag (gtag.js) - Google Analytics