资源描述:
《对groupby子句的扩展》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、对GROUPBY子句的扩展目标通过本章学习,您将可以:使用ROLLUP操作分组使用CUBE操作分组使用GROUPING函数处理ROLLUP或CUBE操作所产生的空值使用GROUPINGSETS操作进行单独分组组函数组函数处理多行返回一个行SELECT[column,]group_function(column)...FROMtable[WHEREcondition][GROUPBYgroup_by_expression][ORDERBYcolumn];SELECTAVG(salary),STDDEV(salary),COU
2、NT(commission_pct),MAX(hire_date)FROMemployeesWHEREjob_idLIKE'SA%';例子:GROUPBY子句SELECTdepartment_id,job_id,SUM(salary),COUNT(employee_id)FROMemployeesGROUPBYdepartment_id,job_id;SELECT[column,]FROMtable[WHEREcondition][GROUPBYgroup_by_expression][ORDERBYcolumn];例子:
3、语法:group_function(column)...HAVING子句使用HAVING对组函数进行限制对查询进行第二次限制SELECT[column,]group_function(column)...FROMtable[WHEREcondition][GROUPBYgroup_by_expression][HAVINGhaving_expression][ORDERBYcolumn];带有ROLLUP和CUBE操作的GROUPBY子句使用带有ROLLUP和CUBE操作的GROUPBY子句产生多种分组结果ROLLUP产生
4、n+1种分组结果CUBE产生2的n次方种分组结果ROLLUP操作符ROLLUP是对GROUPBY子句的扩展ROLLUP产生n+1种分组结果,顺序是从右向左SELECT[column,]group_function(column)...FROMtable[WHEREcondition][GROUPBY[ROLLUP]group_by_expression][HAVINGhaving_expression];[ORDERBYcolumn];ROLLUP应用举例SELECTdepartment_id,job_id,SUM(sal
5、ary)FROMemployeesWHEREdepartment_id<60GROUPBYROLLUP(department_id,job_id);123CUBE操作符CUBE是对GROUPBY子句的扩展CUBE会产生类似于笛卡尔集的分组结果SELECT[column,]group_function(column)...FROMtable[WHEREcondition][GROUPBY[CUBE]group_by_expression][HAVINGhaving_expression][ORDERBYcolumn];CUB
6、E应用举例SELECTdepartment_id,job_id,SUM(salary)FROMemployeesWHEREdepartment_id<60GROUPBYCUBE(department_id,job_id);1234GROUPING函数GROUPING函数可以和CUBE或ROLLUP结合使用使用GROUPING函数,可以找到哪些列在该行中参加了分组使用GROUPING函数,可以区分空值产生的原因GROUPING函数返回0或1SELECT[column,]group_function(column).,GROU
7、PING(expr)FROMtable[WHEREcondition][GROUPBY[ROLLUP][CUBE]group_by_expression][HAVINGhaving_expression][ORDERBYcolumn];GROUPING函数举例SELECTdepartment_idDEPTID,job_idJOB,SUM(salary),GROUPING(department_id)GRP_DEPT,GROUPING(job_id)GRP_JOBFROMemployeesWHEREdepartment_id
8、<50GROUPBYROLLUP(department_id,job_id);213GROUPINGSETSGROUPINGSETS是对GROUPBY子句的进一步扩充使用GROUPINGSETS在同一个查询中定义多个分组集Oracle对GROUPINGSETS子句指定的分组集进行分组后用UNIONALL