`
Neil_yang
  • 浏览: 130103 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

sql中 with rollup 、with cube、grouping 统计函数用法

阅读更多
SQL code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ -->with rollup 、with cube、grouping CUBE 和 ROLLUP 之间的区别在于: CUBE 生成的结果集显示了所选列中值的所有组合的聚合。 ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合。 grouping: 当用 CUBE 或 ROLLUP 运算符添加行时,附加的列输出值为1,当所添加的行不是由 CUBE 或 ROLLUP 产生时,附加列值为0。 --例如 DECLARE @T TABLE(名称 VARCHAR(1) , 出版商 VARCHAR(10), 价格1 INT, 价格2 INT) INSERT @T SELECT 'a', '北京', 11, 22 UNION ALL SELECT 'a', '四川', 22, 33 UNION ALL SELECT 'b', '四川', 12, 23 UNION ALL SELECT 'b', '北京', 10, 20 UNION ALL SELECT 'b', '昆明', 20, 30 SELECT 名称, 出版商, SUM(价格1) AS 价格1, SUM(价格2) AS 价格2, GROUPING(名称) AS CHECK名称, GROUPING(出版商) AS CHECK出版商 FROM @T GROUP BY 名称,出版商 WITH CUBE /* 名称 出版商 价格1 价格2 CHECK名称 CHECK出版商 ---- ---------- ----------- ----------- ------- -------- a 北京 11 22 0 0 a 四川 22 33 0 0 a NULL 33 55 0 1 b 北京 10 20 0 0 b 昆明 20 30 0 0 b 四川 12 23 0 0 b NULL 42 73 0 1 NULL NULL 75 128 1 1 NULL 北京 21 42 1 0 NULL 昆明 20 30 1 0 NULL 四川 34 56 1 0 (所影响的行数为 11 行) */ --分析 /*group by 两列:名称有两个类别A,B;所有由CUBE运算而生成行的是 名称 出版商 价格1 价格2 CHECK名称 CHECK出版商 ---- ---------- ----------- ----------- ------- -------- a NULL 33 55 0 1 b NULL 42 73 0 1 出版商有三个类别,所有由CUBE运算而生成行的是 名称 出版商 价格1 价格2 CHECK名称 CHECK出版商 ---- ---------- ----------- ----------- ------- -------- NULL 北京 21 42 1 0 NULL 昆明 20 30 1 0 NULL 四川 34 56 1 0 以及 NULL NULL 75 128 1 1 */ SELECT 名称, 出版商, SUM(价格1) AS 价格1, SUM(价格2) AS 价格2 FROM @T GROUP BY 名称,出版商 WITH ROLLUP /* 名称 出版商 价格1 价格2 ---- ---------- ----------- ----------- a 北京 11 22 a 四川 22 33 a NULL 33 55 b 北京 10 20 b 昆明 20 30 b 四川 12 23 b NULL 42 73 NULL NULL 75 128 */
分享到:
评论

相关推荐

    Sql学习第四天——SQL 关于with cube,with rollup和grouping解释及演示

    `CUBE`和`ROLLUP`是`WITH`子句中的两个特殊运算符,它们主要用于多维度数据分析和聚合操作,通常在`GROUP BY`语句中配合使用。 1. **CUBE运算符**: `CUBE`生成的结果集包含了所有可能的子集,即所选列中值的所有...

    Oracle ROLLUP和CUBE 用法

    Oracle数据库中的ROLLUP和CUBE是两种用于生成数据汇总的SQL操作,它们在数据分析和报告制作中非常有用。本文将详细介绍这两个概念以及如何在实际应用中使用它们。 首先,我们来理解`ROLLUP`。ROLLUP操作是GROUP BY...

    oracle中聚合函数的扩展使用(ROLLUP CUBE、GROUPING()函数与ROLLUP、CUBE的结合使用等)

    Oracle数据库中的聚合函数是SQL查询中的重要组成部分,用于对数据进行汇总统计。当我们需要更复杂的分组和汇总信息时,可以使用扩展的聚合功能,如ROLLUP、CUBE以及GROUPING()和GROUPING_ID()函数。这些功能允许我们...

    GROUP BY子句(rollup,cube,grouping sets)实例说明

    GROUP BY 子句是 SQL 语言中用于分组数据的关键字,它可以根据一个或多个列对数据进行分组,并对每个分组应用聚合函数,以便计算和输出所需的结果。GROUP BY 子句有多种形式,本文将通过实例来说明 GROUP BY 子句的...

    rollup,cube,grouping sets()的个人理解

    而在更复杂的场景下,为了方便地处理多级别的汇总数据,SQL提供了三种额外的语法:`ROLLUP`、`CUBE`以及`GROUPING SETS()`。这些语法可以帮助我们更加灵活地处理分组结果,并且可以有效地减少查询次数,提高效率。 ...

    rollup cube grouping sets的用法

    在数据库查询语言 SQL 中,`ROLLUP`, `CUBE`, 和 `GROUPING SETS` 是三个重要的概念,它们主要用于处理多维度数据的汇总和分组问题,使得数据分析更加灵活高效。接下来,我们将详细介绍这三个概念的原理、语法以及...

    SQLServer中汇总功能的使用GROUPING,ROLLUP和CUBE

    总的来说,GROUPING、ROLLUP和CUBE是SQL Server中增强数据分析能力的重要工具,它们能够帮助用户更有效地探索和理解数据,生成多层次、多角度的汇总报告。通过熟练掌握这些技术,数据库管理员和数据分析师可以更好地...

    cube与rollup学习总结

    在使用`CUBE`或`ROLLUP`时,为了区分哪些字段被分组了,哪些没有被分组,通常会使用`GROUPING`函数。`GROUPING`函数会根据其参数是否被分组返回一个值:如果参数未被分组,则返回0;如果参数被分组,则返回1。 **...

    grouping 解释及演示.rar

    总结起来,`GROUP BY`、`WITH CUBE`、`WITH ROLLUP`和`GROUPING`是SQL中的高级聚合技术,它们允许我们在数据探索和分析中进行复杂的汇总操作。理解并熟练运用这些概念,可以帮助我们更好地理解数据,从而做出更明智...

    rollup及cube的使用

    ### Oracle中的ROLLUP与CUBE使用详解 在Oracle数据库中,`ROLLUP`与`CUBE`是非常重要的分组函数,被广泛应用于数据汇总、数据分析等场景中。这两个功能可以帮助开发人员快速地对数据进行多维度分析,是开发人员必备...

    grouping or grouping_id in ORACLE

    这两种函数主要用于处理复杂的分组情况,尤其是在使用`ROLLUP` 或 `CUBE` 时更为显著。下面将详细介绍这两者的工作原理以及如何在实际查询中使用它们。 ### GROUPING `GROUPING` 函数用于标识每个汇总行是否属于...

    SQLSERVER中union,cube,rollup,cumpute运算符使用说明

    GROUPING函数可以帮助区分由CUBE生成的NULL值和数据中原本的NULL值,GROUPING函数返回值为1表示是CUBE生成的,为0则表示数据中的原始值。 接着,ROLLUP运算符类似于CUBE,但它生成的结果是分层的,即逐步增加或减少...

    《Pro Oracle SQL》Chapter7 --7.6Eliminate NULLs with the GROUPING() Function

    这个函数通常与GROUPING SETS、CUBE或ROLLUP等高级分组技术结合使用,帮助用户更灵活地处理NULL值和其他分组情况。 例如,如果我们有一个包含产品信息的数据表,其中有些产品的供应商信息可能是NULL,我们可能想要...

    oracle中的grouping

    本文将详细解释`GROUPING`函数的使用方法及其应用场景,并通过一个示例来帮助理解其工作原理。 #### 一、`GROUPING`函数简介 `GROUPING`函数主要用于标识列是否被包含在`GROUP BY`子句中。当某列未被`GROUP BY`...

    group by 后 使用 rollup 子句 总结.doc

    为了更好地管理和呈现查询结果,SQL 还提供了几个辅助函数来配合 `ROLLUP` 的使用: 1. **`grouping()` 函数** 必须接受一列且只能接受一列作为其参数。当该列值为空时返回 1,否则返回 0。 2. **`grouping_id()...

    《Pro Oracle SQL》Chapter7 Advanced Grouping -- 7.5Putting CUBE To Work

    《Pro Oracle SQL》Chapter 7 Advanced Grouping 是一本关于Oracle SQL高级分组技术的专业书籍,其中7.5小节着重讲解了CUBE操作在实际工作中的应用。CUBE是SQL中的一种多维度分析工具,它允许我们在数据分组时生成...

Global site tag (gtag.js) - Google Analytics