• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > Oracle rollup和cube分析

Oracle rollup和cube分析

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了Oracle,rollup,cube,分析,rollup,是等相关知识,希望本文的分享对您有所帮助

rollup是对group by的扩展,会进行小计和合计,而cube包含rollup,是粒度更精细的小计和合计。当只有一个字段时,rollup和cube是一样的。 可用grouping对rollup和cube进行测试:0看;1不看[看表示列有显示,不看表示没有显示] ① rollup ㈠ 什么都不看 ㈡ 从

rollup是对group by的扩展,会进行小计和合计,而cube包含rollup,是粒度更精细的小计和合计。当只有一个字段时,rollup和cube是一样的。

可用grouping对rollup和cube进行测试:0看;1不看[看表示列有显示,不看表示没有显示]

① rollup

㈠ 什么都不看

㈡ 从左往右

-

┌ 先看第1个

│ 再看前2个

└ 后看前3个

② cube:0、1全排列

rollup

rollup后面指定的列以逗号分隔,rollup的计算结果和其后面指定的列的顺序有关,因为rollup的分组具有方向性。若指定n列,则有n+1种分组方式。可改变列的顺序,达到不同的业务需求。一定要牢记列的顺序对结果的影响!

例子:

1.20:32:51 scott@ORCL (^ω^) select a.dname,b.job,sum(b.sal) sum_sal,grouping(a.dname),grouping(b.job)
2.20:33:06 2 from dept a,emp b
3.20:33:06 3 where a.deptno=b.deptno
4.20:33:06 4 group by rollup(a.dname,b.job)
5.20:33:08 5 /
6.
7.DNAME JOB SUM_SAL GROUPING(A.DNAME) GROUPING(B.JOB)
8.---------- ---------- ---------- ----------------- ---------------
9.SALES CLERK 950 0 0
10.SALES MANAGER 2850 0 0
11.SALES SALESMAN 5600 0 0
12.SALES 9400 0 1
13.RESEARCH CLERK 1200 0 0
14.RESEARCH ANALYST 7000 0 0
15.RESEARCH MANAGER 2975 0 0
16.RESEARCH 11175 0 1
17.ACCOUNTING CLERK 1300 0 0
18.ACCOUNTING MANAGER 2450 0 0
19.ACCOUNTING PRESIDENT 5000 0 0
20.ACCOUNTING 8750 0 1
21. 29325 1 1
22.
23.已选择13行。
解释:什么都不看(1,1);从左往右,先看第一个(0,1)

可以将不需要进行小计和合计的列移出rollup,要小计的留在rollup里面。

比如:

1.20:48:37 scott@ORCL (^ω^) select a.dname,b.job,sum(b.sal) sum_sal,grouping(a.dname),grouping(b.job)
2.20:57:43 2 from dept a,emp b
3.20:57:43 3 where a.deptno=b.deptno
4.20:57:43 4 group by a.dname,rollup(b.job)
5.20:57:45 5 /
6.
7.DNAME JOB SUM_SAL GROUPING(A.DNAME) GROUPING(B.JOB)
8.---------------------------- ------------------ ---------- ----------------- ---------------
9.SALES CLERK 950 0 0
10.SALES MANAGER 2850 0 0
11.SALES SALESMAN 5600 0 0
12.SALES 9400 0 1
13.RESEARCH CLERK 1200 0 0
14.RESEARCH ANALYST 7000 0 0
15.RESEARCH MANAGER 2975 0 0
16.RESEARCH 11175 0 1
17.ACCOUNTING CLERK 1300 0 0
18.ACCOUNTING MANAGER 2450 0 0
19.ACCOUNTING PRESIDENT 5000 0 0
20.ACCOUNTING 8750 0 1
21.
22.已选择12行。
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅析drop user与delete from mysql.user的区别
  • mysql prompt的用法详解
  • 如何使用索引提高查询速度
  • 深入mysql创建自定义函数与存储过程的详解
  • JDBC数据库的使用操作总结
  • MySQL查询优化:LIMIT 1避免全表扫描提高查询效率
  • MySQL与Oracle的语法区别详细对比
  • 有关mysql中ROW_COUNT()的小例子
  • MySQL 百万级分页优化(Mysql千万级快速分页)
  • 从创建数据库到存储过程与用户自定义函数的小感

相关文章

  • 2017-05-11MySQL禁用InnoDB引擎的方法
  • 2017-05-11mysql myisam 优化设置设置
  • 2018-12-05oracle 集合
  • 2018-12-05mysql下优化表和修复表命令使用说明(REPAIR TABLE和OPTIMIZE TAB
  • 2018-12-05排名前十的SQL和NoSQL数据库
  • 2018-12-05SQL 查询性能优化 解决书签查找
  • 2018-12-05Mac OS10.11下mysql5.7.12 安装配置图文教程步骤
  • 2018-12-05免安转MySQL服务的启动与停止方法
  • 2018-12-05在数据库中自动生成编号的实现方法分享
  • 2018-12-05MySQL基础教程10 — 函数之全文搜索功能

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql筛选GROUP BY多个字段组合时的用法分享
    • Mysql的limit用法与几种分页形式
    • jdbc调用mysql存储过程实现代码
    • MySQL学习笔记之创建、删除、修改表的方法_MySQL
    • 【设置字符集】Win7 64位系统安装MySQL5.5.21图解教程_MySQL
    • 深入理解MySQL进阶漂流记(二)
    • 封装mysql的JDBC该如何操作
    • ubuntu linux下使用Qt连接MySQL数据库的方法
    • MySQL之递归小问题实例分享
    • 关于mysql_errno()的5篇文章推荐

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有