`
zhuqinglin
  • 浏览: 27758 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

oracle中where 子句和having子句中的区别

 
阅读更多
1.where 不能放在GROUP BY 后面
2.HAVING 是跟GROUP BY 连在一起用的,放在GROUP BY 后面,此时的作用相当于WHERE
3.WHERE 后面的条件中不能有聚集函数,比如SUM(),AVG()等,而HAVING 可以
Where和Having都是对查询结果的一种筛选,说的书面点就是设定条件的语句。下面分别说明其用法和异同点。注:本文使用字段为oracle数据库中默认用户scott下面的emp表,sal代表员工工资,deptno代表部门编号。
一、聚合函数
    说明前我们先了解下聚合函数:聚合函数有时候也叫统计函数,它们的作用通常是对一组数据的统计,比如说求最大值,最小值,总数,平均值(
MAX,MIN,COUNT, AVG)等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。简单举个例子:SELECT SUM(sal) FROM emp,这里的SUM作用是统计emp表中sal(工资)字段的总和,结果就是该查询只返回一个结果,即工资总和。通过使用GROUP BY 子句,可以让SUM 和 COUNT 这些函数对属于一组的数据起作用。
二、where子句
    where自居仅仅用于从from子句中返回的值,from子句返回的每一行数据都会用where子句中的条件进行判断筛选。where子句中允许使用比较运算符(>,<,>=,<=,<>,!=|等)和逻辑运算符(and,or,not)。由于大家对where子句都比较熟悉,在此不在赘述。
三、having子句
    having子句通常是与order by 子句一起使用的。因为having的作用是对使用group by进行分组统计后的结果进行进一步的筛选。举个例子:现在需要找到部门工资总和大于10000的部门编号?
第一步:
select deptno,sum(sal) from emp group by deptno;
筛选结果如下:
DEPTNO   SUM(SAL)
------ ----------
    30       9400
    20      10875
    10       8750
可以看出我们想要的结果了。不过现在我们如果想要部门工资总和大于10000的呢?那么想到了对分组统计结果进行筛选的having来帮我们完成。
第二步:



select deptno,sum(sal) from emp group by deptno having sum(sal)>10000;
筛选结果如下:
DEPTNO   SUM(SAL)
------ ----------
    20      10875
当然这个结果正是我们想要的。
四、下面我们通过where子句和having子句的对比,更进一步的理解它们。
    在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行,简单的理解为只有有了统计结果后我才能执行筛选啊。where子句在查询过程中执行优先级别优先于聚合语句(sum,min,max,avg,count),因为它是一句一句筛选的。HAVING子句可以让我们筛选成组后的对各组数据筛选。,而WHERE子句在聚合前先筛选记录。如:现在我们想要部门号不等于10的部门并且工资总和大于8000的部门编号?
我们这样分析:通过where子句筛选出部门编号不为10的部门,然后在对部门工资进行统计,然后再使用having子句对统计结果进行筛选。

select deptno,sum(sal) from emp
where deptno!='10' group by deptno
having sum(sal)>8000;
筛选结果如下:
DEPTNO   SUM(SAL)
------ ----------
    30       9400
    20      10875
不做太多解释了,这个简单的小例子能够很好的说明where和having的作用。
五、异同点
     它们的相似之处就是定义搜索条件,不同之处是where子句为单个筛选而having子句与组有关,而不是与单个的行有关。
     最后:理解having子句和where子句最好的方法就是基础select语句中的那些句子的处理次序:where子句只能接收from子句输出的数据,而having子句则可以接受来自group by,where或者from子句的输入。
分享到:
评论

相关推荐

    oracle中where 子句和having子句中的区别介绍

    在Oracle数据库中,`WHERE`子句和`HAVING`子句都是用于限制查询结果的条件,但它们在SQL查询中的使用场景和功能有所差异。 首先,`WHERE`子句主要用于在`FROM`子句中指定的表或联接后的结果集上筛选行。它在查询...

    where和having的区别

    ### Oracle SQL 中 WHERE 和 HAVING 的区别 在数据库查询语言SQL中,`WHERE`和`HAVING`子句都是用于过滤数据的关键字,但它们的应用场景和语法结构有着明显的不同。下面将详细介绍这两个关键字的区别。 #### 1. ...

    sql/having用法

    SQL中的HAVING子句用法 HAVING子句是SQL中的一种子句,用于对 GROUP BY 子句所确定的行组进行控制。HAVING 子句条件中只允许涉及常量、聚组函数或 GROUP BY 子句中的列。在 Oracle 中,HAVING 子句是对 GROUP BY ...

    Oracle提高SQL查询效率(SQL优化).doc

    本文将详细介绍 Oracle 中提高 SQL 查询效率的技巧和策略,包括选择最有效率的表名顺序、WHERE 子句中的连接顺序、SELECT 子句中避免使用‘*’、减少访问数据库的次数、使用 DECODE 函数、整合简单的数据库访问、...

    提高Oracle中SQL的执行效率

    本文将详细介绍几种有效的方法来提高Oracle中SQL的执行效率,包括选择合适的表名顺序、优化WHERE子句中的连接顺序、减少不必要的数据库访问等策略。 #### 1. 选择最有效率的表名顺序 在基于规则的优化器中,Oracle...

    oracle数据库优化大全(面试和学习都适用)

    本文总结了 30 多条 Oracle 数据库优化的经验,涵盖了选择最有效率的表名顺序、WHERE 子句中的连接顺序、SELECT 子句中避免使用 ‘*‘、减少访问数据库的次数、使用 DECODE 函数来减少处理时间、整合简单、无关联的...

    oracle SQL优化技巧

    在基于规则的优化器中,Oracle 的解析器按照从右到左的顺序处理 FROM 子句中的表名。因此,在 FROM 子句中写在最后的表(基础表)将被最先处理。在 FROM 子句中包含多个表的情况下,需要选择记录条数最少的表作为...

    oracle查询效率

    10. **用WHERE子句替换HAVING子句**:WHERE子句在数据检索之前执行,而HAVING子句在聚合后过滤结果。尽可能使用WHERE以减少计算成本,尤其是在无需计算字段过滤的情况下。 在多表联接查询中,ON、WHERE和HAVING的...

    oracle性能调优总结大全

    在 Oracle 中,解析器按照从右到左的顺序处理 FROM 子句中的表名。因此,在 FROM 子句中写在最后的表(基础表 driving table)将被最先处理。在 FROM 子句中包含多个表的情况下,必须选择记录条数最少的表作为基础表...

    SQL语句优化在Oracle数据库中的应用.pdf

    3. 优化WHERE子句和HAVING子句:在编写SQL查询语句时,应当优先使用WHERE子句而不是HAVING子句。WHERE子句在查询时依次选择记录,而HAVING子句则是在分组之后对组进行操作,因此WHERE子句的效率更高。 通过对上述...

    oracle语句优化方案

    Oracle自下而上解析WHERE子句,因此表之间的连接条件应位于其他WHERE条件之前,且应将过滤掉最多记录的条件置于WHERE子句的末尾,以尽早剔除不满足条件的记录,减少后续处理的开销。 #### SELECT子句避免使用通配符...

    优化oracle中的sql语句.docx

    10. **用WHERE子句替换HAVING子句**:WHERE子句在数据检索前过滤记录,而HAVING在聚合操作后过滤,因此在可以提前过滤的情况下,使用WHERE子句更高效。 这些优化策略是针对Oracle SQL语句进行性能提升的基本方法。...

    Oracle sql语句多表关联查询

    本文将详细介绍 Oracle SQL 语句多表关联查询的知识点,包括字符串和数字的比较、分组查询、HAVING 子句、查询顺序、Oracle 中的伪列、子查询和表连接等。 一、字符串和数字的比较 在 Oracle 中,字符串和数字可以...

    Oracle性能优化技巧

    10. **Where子句优于Having子句**:在可能的情况下,使用WHERE子句替换HAVING子句,因为在数据检索后过滤数据会增加额外的处理负担。HAVING用于分组后的过滤,而WHERE在分组前过滤。 11. **减少对表的查询**:尽量...

    Oracle SQL性能优化

    2. **WHERE子句中的连接顺序**:Oracle解析WHERE子句时,从下到上进行。应将能够过滤最多记录的条件放在最后,以尽早减少数据量。 3. **SELECT子句避免使用通配符‘*’**:使用‘*’会导致Oracle解析所有列,增加...

    东软oracle期中2.[参照].pdf

    1. **WHERE子句与HAVING子句的区别**: WHERE子句用于筛选满足特定条件的行,而HAVING子句则在GROUP BY之后对分组后的数据进行过滤。在问题1中,如果想限制只包含收入超过15000的雇员,应使用HAVING子句,因为WHERE...

    《Pro Oracle SQL》Chapter7 Advanced Grouping -- 7.2HAVING Clause

    总之,《Pro Oracle SQL》中的这一章节深入介绍了`HAVING`子句的用法,帮助读者掌握如何在Oracle数据库环境中有效地进行分组和条件筛选,提升SQL查询的灵活性和实用性。通过实践和理解提供的示例脚本,读者将能够将...

    Oracle性能问题总结

    * 将过滤条件尽可能放到 Where 子句中,而不是放到 Having 子句中 * 在 SQL 语句中,要减少对表的查询,特别是在含有子查询的 SQL 子句中 * 使用表的别名可以减少解析的时间并避免引起歧义 * 使用 exists 替代 in * ...

Global site tag (gtag.js) - Google Analytics