常用的函数:
            ·:统计个数: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. [学习一个] Matlab GUI 学习笔记 Ⅰ

    Matlab GUI 学习笔记 Ⅰ 1. Foreword Matlab 是严格意义上的编程语言吗?曾经有人告诉我他是通过 Matlab 学会了面对对象编程,我是不信的,但这依然不妨碍它在特殊领域的强 ...

  2. linux 基本命令2(12月27日笔记)

    1.ifconfig 作用:用于操作网卡相关的指令 简单语法:#ifconfig      (获取网卡信息)   2.reboot 作用:重新启动计算机 语法1:#reboot             ...

  3. Linux let 命令

    命令:let let 命令是 BASH 中用于计算的工具,用于执行一个或多个表达式,变量计算中不需要加上 $ 来表示变量.如果表达式中包含了空格或其他特殊字符,则必须引起来. 语法格式 let arg ...

  4. 每日质量NPM包拖拽文件上传_react-dropzone

    一.react-dropzone 官方定义: Simple HTML5-compliant drag'n'drop zone for files built with React.js. 理解: 一个 ...

  5. ECMAScript6语法重点(一)

    一. let和const ①let声明的变量只在它的块作用域有效({ }括起来) ②let不能重复声明同一变量 ③const声明的常量不能改(但对象可以加属性) ④const也有块作用域概念 ⑤con ...

  6. 【BZOJ】3209: 花神的数论题

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3209 显然是按照二进制位进行DP. 考虑预处理$F[i][j]$表示到了二进制的第$i$位 ...

  7. 四: 使用vue搭建网站前端页面

    ---恢复内容开始--- 在搭建路由项目的时候的基本步骤 一:创建项目 安装好vue 搭好环境 (步骤在上篇博客中) 进入项目目录      cd   目录路径/ 目录名 创建项目          ...

  8. composer require 指定版本

    默认 composer require endroid/qr-code 指定版本 composer require endroid/qr-code 1.9.3 # composer require e ...

  9. P493 brass

    实现多态共有继承的两种方法 1 在派生类中重新定义基类的方法 2 使用虚方法 P493程序清单13.7使用的方法为在派生类中重新定义基类的方法 brass.h #ifndef BRASS_H #def ...

  10. Qt基本布局(QLayout)

    概述 Qt提供了QHBoxLayout类(水平排列布局),QVBoxLayout类(垂直排列布局),QGridLayout类(网格排列布局)等基本布局管理.它们之间的继承关系如下图 布局中常用的方法有 ...