欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    Les17oracle数据库教程.ppt

    • 资源ID:6511011       资源大小:300.50KB        全文页数:28页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Les17oracle数据库教程.ppt

    ,对 GROUP BY 子句的扩展,目标,通过本章学习,您将可以:使用 ROLLUP 操作分组使用 CUBE 操作分组使用 GROUPING 函数处理 ROLLUP 或 CUBE操作所产生的空值使用 GROUPING SETS 操作进行单独分组,组函数,组函数处理多行返回一个行,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUP BYgroup_by_expressionORDER BYcolumn;,SELECT AVG(salary),STDDEV(salary),COUNT(commission_pct),MAX(hire_date)FROM employeesWHERE job_id LIKE SA%;,例子:,GROUP BY 子句,SELECT department_id,job_id,SUM(salary),COUNT(employee_id)FROM employeesGROUP BY department_id,job_id;,SELECTcolumn,FROMtableWHEREconditionGROUP BYgroup_by_expressionORDER BYcolumn;,例子:,语法:,group_function(column).,HAVING 子句,使用 HAVING 对组函数进行限制对查询进行第二次限制,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUP BYgroup_by_expressionHAVING having_expression ORDER BYcolumn;,带有ROLLUP 和CUBE 操作的GROUP BY 子句,使用带有ROLLUP 和 CUBE 操作的GROUP BY 子句产生多种分组结果ROLLUP 产生n+1种分组结果CUBE 产生2的n次方种分组结果,ROLLUP 操作符,ROLLUP 是对 GROUP BY 子句的扩展ROLLUP 产生n+1种分组结果,顺序是从右向左,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUP BYROLLUP group_by_expressionHAVING having_expression;ORDER BYcolumn;,ROLLUP 应用举例,1,2,3,CUBE 操作符,CUBE是对 GROUP BY 子句的扩展CUBE 会产生类似于笛卡尔集的分组结果,SELECTcolumn,group_function(column).FROMtableWHEREconditionGROUP BYCUBE group_by_expressionHAVING having_expressionORDER BYcolumn;,CUBE 应用举例,SELECT department_id,job_id,SUM(salary)FROM employees WHERE department_id 60GROUP BY CUBE(department_id,job_id);,1,2,3,4,GROUPING 函数,GROUPING 函数可以和 CUBE 或 ROLLUP 结合使用使用 GROUPING 函数,可以找到哪些列在该行中参加了分组使用 GROUPING 函数,可以区分空值产生的原因GROUPING 函数返回 0 或 1,SELECT column,group_function(column).,GROUPING(expr)FROM tableWHERE conditionGROUP BY ROLLUPCUBE group_by_expressionHAVING having_expressionORDER BY column;,GROUPING 函数举例,SELECT department_id DEPTID,job_id JOB,SUM(salary),GROUPING(department_id)GRP_DEPT,GROUPING(job_id)GRP_JOBFROM employeesWHERE department_id 50GROUP BY ROLLUP(department_id,job_id);,2,1,3,GROUPING SETS,GROUPING SETS 是对GROUP BY 子句的进一步扩充使用 GROUPING SETS 在同一个查询中定义多个分组集Oracle 对 GROUPING SETS 子句指定的分组集进行分组后用 UNION ALL 操作将各分组结果结合起来 Grouping set 的优点:只进行一次分组即可不必书写复杂的 UNION 语句GROUPING SETS 中包含的分组项越多,性能越好。,GROUPING SETS应用举例,SELECT department_id,job_id,manager_id,avg(salary)FROM employeesGROUP BY GROUPING SETS(department_id,job_id),(job_id,manager_id);,1,2,复合列,复合列是被作为整体处理的一组列的集合ROLLUP(a,d)使用括号将若干列组成复合列在ROLLUP 或 CUBE 中作为整体进行操作在ROLLUP 或 CUBE中,复合列可以避免产生不必要的分组结果,(b,c),复合列应用举例,SELECT department_id,job_id,manager_id,SUM(salary)FROM employees GROUP BY ROLLUP(department_id,(job_id,manager_id);,2,1,3,连接分组集,连接分组集可以产生有用的对分组项的结合将各分组集,ROLLUP 和 CUBE 用逗号连接 Oracle 自动在 GROUP BY 子句中将各分组集进行连接 连接的结果是对各分组生成笛卡尔集,GROUP BY GROUPING SETS(a,b),GROUPING SETS(c,d),连接分组集应用举例,SELECT department_id,job_id,manager_id,SUM(salary)FROM employeesGROUP BY department_id,ROLLUP(job_id),CUBE(manager_id);,1,2,3,4,总结,通过本章学习,您已经可以:使用 ROLLUP 操作符使用 CUBE 操作符使用 GROUPING 函数处理在 ROLLUP 或 CUBE中产生的空值使用 GROUPING SETS 创建分组集在 GROUP BY 子句中组合分组:复合列连接分组集,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,Hidden Slide,

    注意事项

    本文(Les17oracle数据库教程.ppt)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开