- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle分组group by的扩展用法 Page ? * 目录 所选列中值的某一层次结构的聚合 所选列中值的所有组合的聚合 对每个参数集做分组 Rollup详解 rollup的语法:group by rollup(列1,列2,列3 …) Group by rollup(A,B,C),分组的先后顺序为 (A,B,C) (A,B) (A) Page ? * Rollup详解 Page ? * Rollup详解 如果报表中只需要小计数据,不需要总计数据时,我们就需要对其做一个过滤,当然在程序中也可以做,但在数据库中更简单,效率也更高 此时的sql语句就需要加入grouping_id了 Page ? * cube详解 Cube的语法:group by cube (列1,列2,列3…) Group by cube(A,B,C),会如下分组 A,B,C A,B A,C A B,C B C Page ? * cube详解 分组组合为(r.stlmonth,r.agentmerid,r.bankid),(r.stlmonth,r.agentmerid),(r.stlmonth,r.bankid),(r.stlmonth),(r.agentmerid,r.bankid),(r.agentmerid),(r.bankid) 7种组合 Page ? * cube详解 Page ? * cube详解 同样取出月小计的数据,需要搭配grouping_id进行取值 Page ? * Grouping_id详解 Page ? * Grouping sets详解 Page ? * Grouping sets的语法 group by grouping sets((分组集合1),(分组集合2),(分组集合3)…) grouping sets((A,B,C),(A,B),(A)),会如下分别分组 A,B,C A,B A 如下是想以(r.stlmonth,r.agentmerid,r.bankid)分组,同时也需要对月分组的数据 Grouping sets详解 Page ? * 使用grouping sets更灵活,可以根据实际 业务需要进行灵活列集合进行分组, grouping sets的使用更简单,不需要再去过滤分组后的数据 Page ? * 推荐使用 针对我们目前业务需要 推荐使用分组扩展的顺序 Rollup搭配grouping_id Cube搭配grouping_id Grouping sets 谢谢! SELECT r.STLMONTH, r.AGENTMERID, r.BANKID, SUM (r.MERAMT) MERAMT FROM LNSTL.T_STL_AGENTMER_RST r GROUP BY ROLLUP ( r.STLMONTH, r.AGENTMERID, r.BANKID ); SELECT r.STLMONTH, r.AGENTMERID, r.BANKID, SUM (r.MERAMT) MERAMT FROM LNSTL.T_STL_AGENTMER_RST r GROUP BY ROLLUP ( r.STLMONTH, r.AGENTMERID, r.BANKID ); SELECT r.STLMONTH, r.AGENTMERID, NVL (r.BANKID, 小计) AS BANKID, SUM (r.MERAMT) MERAMT FROM LNSTL.T_STL_AGENTMER_RST r GROUP BY ROLLUP ( r.STLMONTH, r.AGENTMERID, r.BANKID ) HAVING GROUPING_ID ( r.STLMONTH, r.AGENTMERID, r.BANKID ) IN (0, 1); SELECT r.STLMONTH, r.AGENTMERID, NVL (r.BANKID, 小计) AS BANKID, SUM (r.MERAMT) MERAMT FROM LNSTL.T_STL_AGENTMER_RST r GROUP BY ROLLUP ( r.STLMONTH, r.AGENTMERID, r.BANKID ) HAVING GROUPING_ID ( r.STLMONTH, r.AGENTMERID, r.BANKID
文档评论(0)