我的编程空间,编程开发者的网络收藏夹
学习永远不晚

高级分组group by 、 group by cube、 group by rollup 使用说明

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

高级分组group by 、 group by cube、 group by rollup 使用说明

1、分别以job和deptno分组求和
select sum(sal),job,deptno from emp group by grouping sets(job,deptno);


2、2^n-1分组(n表示列的数量,如果有括号里面的括起来的多个列算一个列 举例:cube((a,b),c)n=2;cube(a,b) n=2;
select sum(sal) ,deptno,job from emp group by cube(deptno,job);
cube__>2^n
     --group by 0;
     --group by job
     --group by deptno
     --group by deptno,job


3、n+1次分组
select sum(sal) ,deptno,job from emp group by rollup(deptno,job);
rullup -->n+1
       --group by deptno,job;
       --group by deptno;
       --group by 0;


4、检测是否参加分组 grouping()
   select sum(sal) ,deptno,job,grouping(deptno),grouping(job) from emp group by cube(deptno,job);
查询的结果集 1 表示没有参与分组;0表示参与分


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

高级分组group by 、 group by cube、 group by rollup 使用说明

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

GROUP BY中的WITH CUBE、WITH ROLLUP原理测试及GROUPING应用

前几天,看到一个群友用WITH ROLLUP运算符。由于自个儿没用过,看到概念及结果都云里雾里的,所以突然来了兴趣对生成结果测了一番。    一、概念:    WITH CUBE:生成的结果集显示了所选列中值的所有组合的聚合。    WITH ROLLUP:生
GROUP BY中的WITH CUBE、WITH ROLLUP原理测试及GROUPING应用
2022-04-12

Mysql之分组查询,Group By,Group Having的用法

一、group by 的用法 group by ,在mysql中用来给字段分组,sql语句如下,这是一条用来统计男女数量的sql语句。 这里我们要注意到,group by ,一定是和聚合函数配合使用的,而不能直接使用select *,当然
2023-08-17

高版本Mysql使用group by分组报错如何解决

这篇文章主要讲解了“高版本Mysql使用group by分组报错如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“高版本Mysql使用group by分组报错如何解决”吧!Mysql5.
2023-03-09

高版本Mysql使用group by分组报错的解决方案

GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组,下面这篇文章主要给大家介绍了关于高版本Mysql使用group by分组报错的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-03-06

高版本Mysql使用group by分组报错的解决方案

mysql5.7版本以上对group by 分组有了新需求,要求group by 后的字段要与select后查询的字段一致,否则就会报错,报错信息如下:#1055 - Expression #1 of SELECT list is not
2023-03-06

Sequelize中用group by进行分组聚合查询

一、SQL与Sequelize中的分组查询1.1 SQL中的分组查询SQL查询中,通GROUP BY语名实现分组查询。GROUP BY子句要和聚合函数配合使用才能完成分组查询,在SELECT查询的字段中,如果没有使用聚合函数就必须出现在OR
2022-06-04

mysql怎么使用left join和group by实现高效查询

这期内容当中小编将会给大家带来有关mysql怎么使用left join和group by实现高效查询,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。mysql高效查询mysql牺牲了group by来增加l
2023-06-15

MySQL踩坑之-- group by 和 limit 组合使用效率优化

应公司业务需求,开发一个费用统计报表;其实本来没啥技术含量,但是踩了一个坑需要记录一下;相信大家在写统计sql的时候,group by是经常会用到的吧,如果数据量过大呢?是不是需要分页,这里就需要用到limit作查询限制,那么问题就来了
2023-08-18

SQLServer 错误 8710 必须提供与 CUBE、ROLLUP 或 GROUPING SET 查询一起使用的聚合函数,才能合并子聚合。 若要修复此问题,请删除该聚合函数或在 GROUP BY

详细信息 Attribute 值 产品名称 MSSQLSERVER 事件 ID 8710 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 QUERY2_CUBE_ILLEGAL_AGG_FUNC ...
SQLServer 错误 8710 必须提供与 CUBE、ROLLUP 或 GROUPING SET 查询一起使用的聚合函数,才能合并子聚合。 若要修复此问题,请删除该聚合函数或在 GROUP BY
2023-11-05

编程热搜

目录