在047考题中有以下这么一道考题
11.View the Exhibit and examine the descriptions of ORDER_ITEMS and ORDERS tables.
   You want to display the CUSTOMER_ID, PRODUCT_ID, and total (UNIT_PRICE multiplied by
   QUANTITY) for the order placed. You also want to display the subtotals for a CUSTOMER_ID as well as
   for a PRODUCT_ID for the last six months.
   Which SQL statement would you execute to get the desired output?
A. SELECT o.customer_id, oi.product_id, SUM(oi.unit_price*oi.quantity) "Total"
   FROM order_items oi JOIN orders o
   ON oi.order_id=o.order_id GROUP BY ROLLUP (o.customer_id,oi.product_id) WHERE MONTHS_BETWEEN(order_date, SYSDATE) <= 6;
B. SELECT o.customer_id, oi.product_id, SUM(oi.unit_price*oi.quantity) "Total"
   FROM order_items oi JOIN orders o
   ON oi.order_id=o.order_id GROUP BY ROLLUP (o.customer_id,oi.product_id) HAVING MONTHS_BETWEEN(order_date, SYSDATE) <= 6;
C. SELECT o.customer_id, oi.product_id, SUM(oi.unit_price*oi.quantity) "Total"
   FROM order_items oi JOIN orders o
   ON oi.order_id=o.order_id GROUP BY ROLLUP (o.customer_id, oi.product_id) WHERE MONTHS_BETWEEN(order_date, SYSDATE) >= 6;
D. SELECT o.customer_id, oi.product_id, SUM(oi.unit_price*oi.quantity) "Total"
   FROM order_items oi JOIN orders o
   ON oi.order_id=o.order_id WHERE MONTHS_BETWEEN(order_date, SYSDATE) <= 6 GROUP BY ROLLUP (o.customer_id, oi.product_id) ;

Answer: D
上面这道题中其实要选择正确的答案是很简单的,就是group by应该放在where的后面,但是题目中出现的一个知识点需要我们注意,就是rollup的使用。
大家都熟悉group by基本语法,例如要统计每个部门的员工最高的工资,就可以使用
select max(sal) from emp group by deptno;
但是如果出现比较复杂的统计,单单靠group by基本用法是不能满足的需求的,还得配合rollup一起来使用,例如:
需要安装职位,经理,部门来统计员工的总工资,并且对职位,经理做一个子统计
SQL> select job,mgr,deptno,sum(sal)  from emp where deptno in(10,30)  group by rollup(job,mgr,deptno);
JOB                                MGR     DEPTNO   SUM(SAL)
--------------------------- ---------- ---------- ----------
CLERK                             7698         30        950
CLERK                             7698                   950
CLERK                             7782         10       1300
CLERK                             7782                  1300
CLERK                                                   2250
MANAGER                           7839         10       2450
MANAGER                           7839         30       2850
MANAGER                           7839                  5300
MANAGER                                                 5300
SALESMAN                          7698         30       5600
SALESMAN                          7698                  5600
JOB                                MGR     DEPTNO   SUM(SAL)
--------------------------- ---------- ---------- ----------
SALESMAN                                                5600
PRESIDENT                                      10       5000
PRESIDENT                                               5000
PRESIDENT                                               5000
                                                       18150
16 rows selected.
那么group by rollup的分组是按照以下步骤,在上述ROLLUP(job,mgr,deptno)例子中,首先会对(job,mgr,deptno)进行GROUP BY,然后对(job,mgr)进行GROUP BY,然后是(job)进行GROUP BY,最后对全表进行GROUP BY操作,结合上述的例子
首先对(job,mgr,deptno)分组,其统计结果类似如下:
CLERK                             7698         30        950
然后对(job,mgr)分组,其统计结果类似如下:
CLERK                             7698                   950
然后对(job)分组,其统计结果类似如下:
CLERK                                                   2250
最后对全表做一次分组统计
                                                       18150
这样分析以下,相信大家对group by rollup查询结构有一个全面的了解


CUUG

更多oracle视频教程请点击:http://crm2.qq.com/page/portalpage/wpa.php?uin=800060152&f=1&ty=1&aty=0&a=&from=6