您当前的位置: AG亚游集团 > 数据库教程 > Oracle教程 > Oracle中用GROUPING SETS分组自定义方法汇总

Oracle中用GROUPING SETS分组自定义方法汇总

作者:guanchaofeng 来源:不详 发布时间: 2009-05-09 12:40 点击: 次
本文通过文章作者的亲身经历来讲解如何在Oracle数据库中使用GROUPINGSETS分组自定义。 当你与COUNT和SUM这类总计函数一起使用GROUPBY语句时,你一般得不到多级总数。GROUPBY中每个唯一的列组合生成一个总数,但这些总数不会累加到更高一级的总数中。 要实现

AG亚游集团,海军军事学术研究所研究员张军社11日接受《环球时报》记者采访时表示,最近几年来,中国海空军飞机经宫古海峡、巴士海峡到西太平洋空域进行训练已经实现常态化。张军社称,所谓“中国突破第一岛链”的说法并不存在。第一岛链是冷战时期美国提出的概念,目的是把中国和前苏联军力困在第一岛链内。日本某些势力妄想和美国联手把中国军力困守在所谓的第一岛链内,这是痴心妄想,日本也没有这种能力。

  研发方面,王秉科称,尽管与国外厂商相比,本地仍旧存在差距,但比较明显的趋势是,“越来越多的国产手机厂商已经意识到了技术掌握的重要性,正在逐年加大研发投入,比如波导每年营收的6%用于产品开发,TCL、夏新、科健在这些方面的成绩也不错”。90后如何白手起家项俊波指出,要坚持保险业姓保,始终站在战略和全局高度,正确把握保险业的定位和发展方向。一是要成为国家发展的稳定器;二是要成为人民生活的保障器;三是要成为实体经济的助推器,成为“脱虚向实”的助推器。实体经济是强国之本,是国家核心竞争力之本,也是保险业健康发展之本。

Oracle中用GROUPING SETS分组自定义方法汇总

  本文通过文章作者的亲身经历来讲解如何在Oracle数据库中使用GROUPINGSETS分组自定义。
  
  当你与COUNT和SUM这类总计函数一起使用GROUPBY语句时,你一般得不到多级总数。GROUPBY中每个唯一的列组合生成一个总数,但这些总数不会“累加”到更高一级的总数中。
  
  要实现这一点,你可以用GROUPBYROLLUP或GROUPBYCUBE替代GROUPBY,不过它们会生成所有可能的总数,而你可能不需要全部总数。对GROUPBYCUBE而言,将会生成2^n组总数,这里的n是GROUPBY中列的数目。
  
  查看下面的查询,它使用了SH样本模式:
  
  SELECTprod_id,cust_id,channel_id,SUM(quantity_sold)FROMsalesWHEREcust_id<3GROUPBYCUBE(prod_id,cust_id,channel_id)
  
  这将生成8组总数:
  
  所有行的总和
  
  每个通道,包括所有产品和顾客。
  
  每个顾客,包括所有产品和通道。
  
  每项产品,包括所有顾客和通道。
  
  每个通道/顾客组合,包括所有产品。
  
  每个通道/产品组合,包括所有顾客。
  
  每个产品/顾客组合,包括所有通道。
  
  每个产品、顾客和通道组合。
  
  可能的组合非常多。GROUPBYCUBE中每增加一列,生成的总数就会翻一番。
  
  可以用GROUPBYGROUPINGSETS来代替GROUPBYCUBE。你可以应用来指定你感兴趣的总数组合。因为它不必计算它不需要集合(也不会产生太多结果),所以对SQL引擎来说更为高效。
  
  其格式为:
  
  GROUPBYGROUPINGSETS((list),(list)...)
  
  这里(list)是圆括号中的一个列序列,这个组合生成一个总数。要增加一个总和,必须增加一个(NUlL)分组集。
  
  例如,如果只要生成每项产品(包括所有顾客和通道)和每个顾客/通道组合(包括所有产品)的总数,可以输入:
  
  SELECTprod_id,cust_id,channel_id,SUM(quantity_sold)FROMsalesWHEREcust_id<3GROUPBYGROUPINGSETS((prod_id),(cust_id,channel_id));
  
  这种方法将这个数据集生成的总数数量从180个减少到37个,并帮助你着重回答你希望解答的问题。

分享到:
本文"Oracle中用GROUPING SETS分组自定义方法汇总"由远航站长收集整理而来,仅供大家学习与参考使用。更多AG亚游集团尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 广告合作 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(AG亚游集团). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类AG亚游集团.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4
北京国安3月1日开新援见面会 巴坎布比埃拉亮相 王室大婚谁牵梅根走红毯?肯辛顿宫:王储查尔斯 气象局:北京等24站连续无降水日数突破历史极值 胡锡进:中美突然握手言和 两边都有些人感觉受伤 道医开“道身”一口价5万 声称能使老人返老还童 俄媒:中国海军发展能力无限 军舰数量已超美国 美国产量创新高+贸易战忧虑 美油重挫2% 李明博接受调查21小时后返家 否认检方主要指控 连续两年挺进季后赛 寂寞大神明年还想搏一把 首钢的“芯”酸往事:从试图自主到放弃“芯”梦 警报!一方已经没多少球可输了 卡拉斯科归队有用么 范卫锋:什么是投资人眼中的优质新媒体项目
刘永富:严肃处理打脱贫攻坚旗号扩大政府债务问题 孙政才对指控事实和罪名均不持异议 Facebook也要自己造芯片了:还有苹果、谷歌和亚马… 跑步时喘得跟拉破的风箱似的?如何破解 美国楼市复苏 外国买家转向谨慎 李晓旭:恢复速度快让我盲目乐观 会找回自己 螺纹钢短期面临回落压力 中国公民赴阿塞拜疆未办登记遭罚款 中使馆发提醒 单节7中6打爆火箭锋线!这瓜甜久点雷霆早稳了 外卖员偷走快递员电动三轮 刚充好电就被抓 进球GIF-巴坎布禁区被绊倒 索里亚诺点球破僵局 新人斑马线上拍婚纱照摆造型 来往车辆被逼停(图)
势不可挡!武磊12分钟完成戴帽 在他身前只有一尊神 优步证实将于6月30日关闭即时快递服务UberRUSH 工信部白皮书:中国区块链产业生态初步形成 场内场外申花和国安杠上了 球迷:韦世豪是上海滩球王 武警部队政治部主任颜晓东中将任武警部队副政委 港媒:北京中关村推绿卡“直通车” 吸引全球人才 证明之战!索萨曾和苏宁谈崩 除孙可外还有故人 输急眼!杜兰特怒喷保罗亲哥 唾沫星子都出来了 河南一公园发生舞台灯架倾倒事故 致一死五伤 亩收益10万的种植品种 养100只肉狗投资多钱 月薪过万十大冷门职业 赚钱最快的八个方法 AG亚游集团