`

oracle中group by的高级应用

 
阅读更多

GROUP BY的语法:

select [filed1,filed2,...]聚合函数(filed),[grouping(filed),][grouping_id(filed1,filed2)]

from tabel_name

where condition

[group by {rollup|cube} (filed1,filed2) ]

[having condition]

[order by filed]

1.where和having的区别:

where和having都是用来筛选数据,但是where是针对原数据进行筛选,而having子句是针对汇总后的结果进行筛选

2.扩展用法:

a.使用rollup操作符:‘rollup’的意思是‘卷起,汇总’,它可以使在括号中的字段,按右到左的顺序分别froup后显示,类似我们用多个group by语句,然后union all起来;

b.使用cube操作符:cube意思是立方,使用该操作符可以对操作符内的字段,进行遍历组合汇总,将操作符内的字段进行不同的组合来进行分组;

c.使用grouping(filed)函数:

用来判断某行数据是不是按照rollup或cube进行汇总,如果判断的该参数为null则返回1,否则返回0

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Oracle 11g数据库应用简明教程

    本教程旨在提供一个Oracle 11g数据库应用的简明指南,帮助初学者快速掌握数据库的基础操作和高级功能。 一、Oracle 11g基础 1. 数据库安装与配置:Oracle 11g的安装过程涉及选择正确的软件版本、配置数据库实例、...

    Oracle高级sql学习与练习

    Oracle高级SQL学习与练习涵盖了数据库编程中的一系列高级主题,旨在帮助数据库开发者和管理员提高解决复杂问题的能力。在Oracle数据库系统中,高级SQL技能是进行高效数据管理、查询优化和复杂数据处理的基础。 1. ...

    oracle group by语句实例测试

    Oracle中的`GROUP BY`语句是SQL查询中的关键部分,用于根据一个或多个列对数据进行分组,以便对每个组执行聚合函数,如`SUM`、`COUNT`、`...在实际应用中,应结合具体的数据结构和业务需求来设计高效的`GROUP BY`查询。

    Oracle高级应用

    在"Oracle高级应用"这个主题中,我们将深入探讨Oracle数据库的一些高级概念和技术,这对于任何在Oracle环境中进行编程或管理数据的人来说都是非常重要的。 1. **函数与操作符**:Oracle SQL提供了丰富的内置函数,...

    oracle sql 高级编程

    Oracle SQL高级编程是针对数据库开发和管理的专业领域,旨在帮助高级编程人员深入理解和掌握SQL在Oracle数据库中的应用。Oracle数据库是世界上最广泛使用的数据库系统之一,它提供了强大的功能和高效的性能,使得SQL...

    Oracle SQL 高级编程 附源码

    HAVING子句用于在GROUP BY之后应用额外的过滤条件,这在处理分组数据时非常有用。 四、窗口函数 窗口函数扩展了SQL的功能,可以在数据集上执行计算,同时保持行的上下文。例如,LEAD和LAG函数可以访问当前行的前一...

    Oracle多行记录合并

    在实际应用中,选择哪种方法取决于具体的需求、数据结构以及Oracle数据库的版本。例如,如果只需要简单的字符串连接,`LISTAGG`通常是首选;如果需要处理复杂的数据关系,可能需要借助`CONNECT BY`或`MODEL`。在使用...

    Oracle SQL高级编程 中文版

    通过阅读《Oracle SQL高级编程》,读者不仅可以掌握Oracle SQL的高级特性,还能学习到如何在实际项目中应用这些知识,从而提升数据库管理与开发的效率和质量。对于DBA来说,这本书也是日常维护和优化数据库的宝贵...

    oracle分组排序统计高级用法

    ### Oracle 分组排序统计高级用法详解 ...在实际应用中,根据具体的需求选择合适的工具和技术组合可以大大提高数据处理的效率和灵活性。希望本文能够帮助读者更好地理解和掌握Oracle中的高级排序和统计技巧。

    《Oracle SQL高级编程》书中源代码

    《Oracle SQL高级编程》这本书是数据库管理员和开发人员深入学习SQL在Oracle数据库系统中应用的宝贵资源。书中涵盖了一系列高级主题,旨在帮助读者提升在数据查询、数据分析、性能优化以及复杂业务逻辑处理等方面的...

    ORACLE学习笔记系列(15)使用扩展的 GROUP BY 子句

    在"ORACLE学习笔记系列(15)使用扩展的 GROUP BY 子句"这篇博文中,作者深入探讨了GROUP BY子句的高级用法,特别是如何利用扩展功能来处理更复杂的查询需求。 在标准的GROUP BY语句中,我们通常会指定一列或多列,...

    自己整理的Oracle常用高级语句.rar

    ROLLUP操作符在GROUP BY子句中使用,生成多层汇总,类似于SQL的“cube”功能,但只计算上一层的数据。这在报表分析中非常有用。 7. **数据链路的使用**: 数据链路是Oracle数据库间通信的方式,允许在不同网络...

    [Oracle.SQL高级编程].Karen.Morton等.扫描版

    高级查询可以利用子查询、连接(JOINs)、分组(GROUP BY)、排序(ORDER BY)、窗口函数、聚合函数等实现复杂的查询逻辑。 5. PL/SQL编程:PL/SQL是Oracle数据库的过程化语言扩展,提供了程序流程控制、变量声明、...

    Oracle常用高级sql学习

    在IT行业中,Oracle数据库因其稳定性和强大的数据处理能力而被广泛应用于企业级应用中。为了更好地管理和查询数据,掌握Oracle的高级SQL技术变得尤为重要。本文将根据提供的标题、描述和部分链接信息,详细介绍...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

    Karen Morton及其团队在本书中提供了专业的方案:先掌握语言特性,再学习Oracle为提升语言效率而加入的支持特性,进而将两者综合考虑并在工作中加以应用。作者通过总结各自多年的软件开发和教学培训经验,与大家...

    Oracle高级SQL培训与讲解

    通过"Oracle高级SQL培训与讲解"的学习,读者将掌握如何编写高效、复杂的SQL查询,更好地管理和优化Oracle数据库,提升数据库应用的性能和用户体验。这个教程会详细解析这些概念,并提供实例演示,帮助学习者深入理解...

    oracle高级查询技巧

    在Oracle数据库系统中,高级查询技巧是提升数据库管理员和程序员工作效率的关键。这些技巧不仅能够帮助我们获取更精确、更高效的数据,还能使数据处理过程更加灵活。以下是对"Oracle高级查询技巧"的详细阐述。 一、...

    oracle 高级复制操作步骤,花了很久才研究透彻。

    ### Oracle高级复制操作详解 ...- 在实际生产环境中应用高级复制前,建议先在测试环境中进行充分的测试。 通过上述步骤,可以有效地完成Oracle高级复制的配置与测试,确保数据的一致性和高效传输。

Global site tag (gtag.js) - Google Analytics