第二章   汇总和聚合数据(一)
admin
2023-05-10 17:22:09
0

为完整地了解Oracle的聚合函数,我们还要知道当数据包含NULL时,情况会怎样。销售奖励只有销售人员才有,非销售人员没有,所以反映在HR.EMPLOYEES表中就是那些非销售人员的COMMISSION_PCT字段的值为NULL。如果想计算或同级COMMISSION_PCT的平均值,或是此字段有值的行的数量,可以用下面的SQL语句列出聚合计算的结果:

   

 select count(commission_pct),avg(commission_pct)
    from hr.employee;


---------------------------------------------------------------

COUNT(COMMISSION_PCT)    AVG(COMMISSION_PCT)

                                           38                                    .255

---------------------------------------------------------------

    虽然我们知道在统计薪水时有107位员工,但在统计销售奖励时,COUNT函数忽略了那些COMMISSION_CPT为NULL值的行,统计出仅有38位员工有销售奖励。同样,当计算员工的平均销售奖励时,Oracle也忽略了NULL值对应的那些行,仅仅计算那些有值的行。

    仅仅在两种特殊情况下,Oracle在聚合函数中考虑了NULL值。第一种是在GROUPING功能里,用来检验包含NULL值的分析函数的结果,是直接由所在的表得来,还是由分析计算得到的最终聚合“NULL集”得来。第二种情况是在COUNT(*)的功能里。因为通配符“*”表示表中所有的字段,所以Oracle忽略任何实际的数据,而单独统计行数,看起来像是把NULL值和普通值一样对待。

    为了演示,下面的SQL语句明确显示了COUNT(*)与COUNT(COMMISSION_PCT)的不同:

    

select count(*),count(commission_pct)
    from hr.employee;


---------------------------------------------

COUNT(*)    COUNT(COMMISSION_PCT)

         107                                               38

---------------------------------------------

    COUNT(*)统计了表中的所有行,而COUNT(COMMISSION_PCT)仅仅统计了表中字段COMMISSION_PCT不为NULL的那些行。  

  

    在分组进行数据汇总时,SELECT语句中选中的字段或值,要么参加聚合计算,要么被涵盖到GROUP BY子句中。若想写出语法正确的GROUP BY子句,就要永远牢记:值要么用来分组,要么用来参加聚合计算——没有其他用途。

    当按聚合或其他函数进行排序时,Oracle提供了排序字段的简化符号。不必在ORDER BY后面累赘地写上字段的全名,直接用他们在SELECT 语句中的位置序号即可。

    

Select department_id, job_id,min(salary), avg(salary), max(salary)
    from hr.employee
    group by department_id, job_id
    order by 1, 5 desc ;


    语句中ORDER BY 子句后面的1与5分别代表SELECT 语句中第一个位置和第五个位置的DEPARTMENT_ID与max(salary)。

    

    基于聚合函数或分组的结果,我们想排除某些数据组。也就是说,我们希望在GROUP BY子句的后面,再跟一个类似WHERE的子句,在分组或聚合之后进行筛选。

    SQL有一个HAVING子句,可以对数据进行选择。HAVING子句的条件可以无限地复杂,所以可以在分组排序中使用复合条件。

    

select department_id, job_id, min(salary), avg(salary), max(salary), count(*)
    from hr.employees
    group by department_id, job_id
    having count(*)>1
    and min(salary) between 2500 and 17000
    and avg(salary) !=5000
    and max(salary)/min(salary)<2;


相关内容

热门资讯

动物园老虎走路颤颤巍巍,园方回... 5月13日,一位网友称在山东德州“泉城欧乐堡”虎餐厅,关注到现场老虎身体发黑,其中一只颤颤巍巍、走路...
热水器40升可以洗多久 一般来说40升的热水器可以洗20-40分钟左右的时间,有差距是因为每个人洗澡时对水的温度要求不同,比...
2020年流行什么样的壁布 2020年最流行的是田园风格的壁布,因为体验风格的壁布适合大部分的装修风格,不管你家里是中式装修还是...
热水器50升和60升哪个实用 1、一般三口之家使用的是50升的,但是机器在加热过程中也会消耗一部分水,所以选60升的也可以。2、以...
煤气热水器不恒温怎么办 煤气热水器不恒温是很常见的问题,会给我们的生活带来很大的不便。这种情况的出现可能是由于多种因素引起的...
恒温热水器没有温度怎么办 如果您的恒温热水器没有温度,那么这可能是一个很大的问题,因为您无法使用这个热水器来满足您的热水需求。...
沈伯洋不认“抗中保台”?徐巧芯... 海峡导报综合报道 民进党13日正式征召民进党民代沈伯洋参选台北市长,蓝绿对决态势至此成形。对此,国民...
宝马线上股东大会“技术故障”背... 【文/观察者网 张家栋 编辑/高莘】当地时间5月13日,据德国《世界报》报道,宝马集团年度股东大会因...
线上预约+线下收购,十部门联合... 2026年夏粮旺季收购即将全面启动。近日,国家发展改革委、国家粮食和物资储备局等十部门联合发出通知,...
赖清德再度缺席弹劾案审查会,国... 台民意机构于5月14日继续召开针对台湾地区领导人赖清德弹劾案的第二次审查会,赖清德与13日一样未出席...