常用的函数:
            ·:统计个数:COUNT(),根据表中的实际数据量返回结果;
            ·:求和:SUM(),是针对于数字的统计,求和
            ·:平均值:AVG(),各种数据类型都支持
            ·:最大值:MAX(),各种数据类型都支持
            ·:最小值:MIN(),求出最小值
      范例:验证各个函数:
            select count(*) 人数,AVG(sal)员工平均工资,SUM(sal)每月总支出,
             max(sal) 最高工资,min(sal)最低工资
             from scott.emp;
      范例:统计出公司的平均雇用年限
            select  avg(months_between(sysdate,hiredate)/12) from scott.emp;
      范例:求出最早和最晚的雇佣日期
            select max(hiredate)最晚,min(hiredate)最早 from scott.emp;
      以上的几个操作函数,在表中没有数据的时候,只有CIUNT()函数会返回结果,其他都是NULL;
      范例:统计bonus表
            select count(*) 人数,AVG(sal)员工平均工资,SUM(sal)每月总支出,
             max(sal) 最高工资,min(sal)最低工资
             from bonus;
      实际上针对于count()函数有三种使用形式;
            ·count(*):可以准确的说返回表中的全部记录数;
            ·count(字段):统计不为null的所有数据量;
            ·connt(DISTINCT 字段);消除重复之后的结果;
      范例:统计查询一
            select count(*),count(empno),count(comm) from scott.emp;
            统计查询二:
            select count (DISTINCT job) from scott.emp;
  5-2:分组统计
      范例:根据部门编号分组、查询出每个部门的编号、人数、平均工资。
            select count(deptno) 编号,count(*),Avg(sal)
              from scott.emp
              group by deptno;
      范例:根据职位分组,统计出每个职位的人数,最低工资与最高工资。
            select job,count(*),min(sal),MAX(sal)
              from scott.emp
              group by job;
  5-3:多表查询与分组统计
      范例:查询出每个部门的名称、部门人数、平均工资。
        确定要使用的数据表
            dept表:部门名称
            emp表:统计数据
        确定已知的关联字段
            雇员与部门:scott.emp.deptno=scott.dept.deptno
      第一步:换个思路,查询出每个部门的名称,雇员编号(count(empno))、基本工资(AVG(sal))
              select d.ename,e.empno,e.sal
                from scott.emp e,scott.emp d
                 where e.deptno=d.deptno;
      第二步:
              select d.ename,count(e.empno),AVG(e.sal)
                 from scott.emp e,scott.emp d
                   where e.deptno=d.deptno
                   group by d.dname;
      第三部:外连接
              select d.dname,count(e.empno),AVG(e.sal)
                   from scott.emp e,scott.emp d
                     where e.deptno(+)=d.deptno
                     group by d.ename;
    范例:查询每个部门的编号、名称、位置、部门人数、平均工资;
          确定要使用的数据表
            dept表:编号、名称、位置
            emp表:统计信息
           确定已知的关联字段
              雇员与部门:scott.emp.deptno=scott.dept.deptno
                select d.deptno,d.dname,d.loc,e.empno,e.sal
                from scott.emp e, scott.dept d
                where e.deptno(+)=d.deptno;
          第二步:此时发现有三个列(dept表)同事发生着重复,呢么就可以进行多字段分组。
                select d.deptno,d.dname,d.loc,count(e.empno),avg(e.sal)
                from scott.emp e, scott.dept d
                where e.deptno(+)=d.deptno
                group by d.deptno,d.dname,d.loc;

oracle 分组查询的更多相关文章

  1. 五、Oracle 分组查询、视图

    一.分组函数1.avg:平均分2.sum:求和3.max:最大值4.min:最小值注意:前面四个必须针对数值字段,且参数只能是一个5.count:求个数 二.分组查询1.语法是 group by 分组 ...

  2. ORACLE分组查询和统计等

    select flow_id,rw from (select t.flow_id ,rownum as rw from apex_030200.wwv_flow_list_templates t)  ...

  3. oracle分组查询实例ORA-00979和ORA-00937错误分析

    select J.ZWJGH,J.CZZXBH,J.JZZT,J.CWNY,J.JZPZH sum(J.FSE)<!-- 聚合函数字段没在分组条件中--> from JZPZXX J &l ...

  4. oracle分组查询

    分组函数 在分组函数中,如果有一个查找项分组,其他项必须也分组,比如下面的语句会报错,因为sal分组了,而ename没有分组: 1.显示工资最高的员工: 2.显示所有员工的平均工资: 2.1使用系统函 ...

  5. oracle 基础SQL语句 多表查询 子查询 分页查询 合并查询 分组查询 group by having order by

    select语句学习 . 创建表 create table user(user varchar2(20), id int); . 查看执行某条命令花费的时间 set timing on: . 查看表的 ...

  6. .Net程序员学用Oracle系列(21):分组查询(GROUP BY)

    1.GROUP BY 标准分组 1.1.GROUP BY 概述 1.2.WHERE 和 HAVING 的区别? 2.GROUP BY 扩展分组 2.1.ROLLUP 分组 2.2.CUBE 分组 2. ...

  7. Oracle和MySQL分组查询GROUP BY

    Oracle和MySQL分组查询GROUP BY 真题1.Oracle和MySQL中的分组(GROUP BY)有什么区别? 答案:Oracle对于GROUP BY是严格的,所有要SELECT出来的字段 ...

  8. Oracle总结【SQL细节、多表查询、分组查询、分页】

    前言 在之前已经大概了解过Mysql数据库和学过相关的Oracle知识点,但是太久没用过Oracle了,就基本忘了...印象中就只有基本的SQL语句和相关一些概念....写下本博文的原因就是记载着Or ...

  9. 【Oracle命令 】使用的sql语句之分组查询(group by)

    由于本人并未对oracle数据库进行深入了解,但是工作中又需要知道一些基础的sql,所以记录下操作的sql语句.方便日后查看 1.将序列号作为分组查询的条件,再将查询出来的结果进行筛选. select ...

随机推荐

  1. 【译】第19节---数据注解-NotMapped

    原文:http://www.entityframeworktutorial.net/code-first/notmapped-dataannotations-attribute-in-code-fir ...

  2. axios的学习与使用

    最近的项目都是使用的vue框架,所以请求都使用了vue官方推荐的axios. 官方中文介绍 此处记录一下常用的写法 执行 GET 请求 // 为给定 ID 的 user 创建请求 axios.get( ...

  3. mime模块响应或设置Node.js的Content-Type头

    转载自:https://itbilu.com/nodejs/core/VJYaAfKrl.html   MIME,即:Multipurpose Internet Mail Extensions,多用途 ...

  4. OpenModelica读取文件

    parameter String file = Modelica.Utilities.Files.loadResource("J:/git/tcs/tcs.txt"); 将文件名变 ...

  5. 把查询的数据导出到elsx表 关于流的概念

    1.获取到需要导出的数据   因为这个对象是PagedResulDto类型的   所以封装成Table的时候  传pageList.Items就可以了 PagedResultDto<Search ...

  6. 30秒了解Excel的前世今生

    JS 大家日常工作离不开的Excel,实际上脱胎于1979年问世的Apple II电脑上的一款杀手级应用VisiCalc. VisiCalc在问世后的6年间,以100美金一份的价格卖出了超过70万份, ...

  7. 从classloader的变更说起

    classloader从1.6到1.7整体分成了两个版本.重点区别就是并行类加载. 1.6版本 protected synchronized Class loadClass(String name, ...

  8. const修饰函数

    #include <iostream> using namespace std; class A { public: A(int age); void printAge() const; ...

  9. MYSQL常用函数(类型转化函数)

    为了进行数据类型转化,MySQL提供了CAST()函数,它可以把一个值转化为指定的数据类型.类型有:BINARY,CHAR,DATE,TIME,DATETIME,SIGNED,UNSIGNED 示例: ...

  10. 移动端rem适配布局

    dome如下: <!doctype html><html><head> <meta charset="UTF-8" /> <m ...