网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.ORACLE入门之简析REDO LOGFILE.
.Oracle 的一些基本知识,应该知道.
.SERVER数据转换ORACLE问题.
.Oracle中用LogMiner分析重做及归.
.ORACLE在HP-UX下的系列问题处理(.
.探讨企业的需求.
.Oracle调优与深入之灌水篇.
.Red Hat 8.0 的电子书.
.Oracle中关数据库对象的统计分析.
.ORACLE数据库容灾复制解决方案sh.
.如果在create controlfile漏掉da.
.[Oracle]发布数据库内容管理的新.
.两个有用Oracle运算:intersect和.
.如何监控Oracle索引的使用完全解.
.你可知道你的Oracle数据库安全吗.
.教你如何收集Oracle进程中的SQL跟.
.问答方式轻松学习Oracle数据库中.
.Oracle字符值的比较和储存.
.关于 分布式oracle中 database l.
.使用DBMS_SUPPORT包(zt).

cube子句的用法

发表日期:2008-2-9



  cube子句在dw环境用的比较多,非凡是在产生交叉报表的情况,演示一个cube的例子
  SQL 10G>create table test(sales varchar2(10),dest varchar2(10),revenue number);
  Table created.
  SQL 10G>insert into test values('smith','hangzhou',1000);
  1 row created.
  SQL 10G>insert into test values('smith','wenzhou',2000);
  1 row created.
  SQL 10G>insert into test values('allen','wenzhou',3000);
  1 row created.
  SQL 10G>insert into test values('allen','wenzhou',4000);
  1 row created.
  SQL 10G>commit;
  Commit complete.
  
  SQL 10G>select * from test;
  SALES   DEST     REVENUE
  ---------- ---------- ----------
  smith   hangzhou     1000
  smith   wenzhou     2000
  allen   wenzhou     3000
  allen   wenzhou     4000
  
  比如说我们想统计每个sales的总销售收入,每个sales在各个城市的销售收入,另外还想知道每个城市所有sales的销售收入总额,以及所有sales的总收入
  
  就像以下报表
      hangzhou wenzhou
  allen          7000   7000
  smith  1000    2000   3000
      1000    9000   10000
  
  
  那我们运行下面这条语句就行了
  SQL 10G>select sales,dest,sum(revenue) from test group by cube(sales,dest);
  SALES   DEST    SUM(REVENUE)
  ---------- ---------- ------------
               10000  所有sales的总销售收入
       wenzhou  9000  所有sales在温州的销售收入
       hangzhou  1000  所有sales在杭州的销售收入
  allen            7000  allen的所有销售收入
  allen    wenzhou   7000  allen在温州的销售收入
  smith            3000  smith所有的销售收入
  smith   wenzhou   2000  smith在温州的销售收入
  smith   hangzhou  1000  smith在杭州的销售收入
  8 rows selected.
  
  假如不想统计城市这个维度,那么用rollup子句
  
      hangzhou wenzhou
  allen    7000  7000
  smith   1000   2000   3000
                   10000
  
  SQL 10G>select sales,dest,sum(revenue) from test group by rollup(sales,dest)
   2 ;
  SALES   DEST    SUM(REVENUE)
  ---------- ---------- ------------
  allen   wenzhou    7000 allen在温州的销售收入
  allen             7000 allen的所有销售收入
  smith   wenzhou   2000 smith在温州的销售收入
  smith   hangzhou   1000 smith在杭州的销售收入
  smith             3000 smith所有的销售收入
                10000 所有sales的总销售收入
  6 rows selected.
上一篇:分析函数lag小技巧 人气:1081
下一篇:如何获得Oracle的隐含参数 人气:643
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐