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`子句都是用于限制查询结果的条件,但它们在SQL查询中的使用场景和功能有所差异。 首先,`WHERE`子句主要用于在`FROM`子句中指定的表或联接后的结果集上筛选行。它在查询...
### Oracle SQL 中 WHERE 和 HAVING 的区别 在数据库查询语言SQL中,`WHERE`和`HAVING`子句都是用于过滤数据的关键字,但它们的应用场景和语法结构有着明显的不同。下面将详细介绍这两个关键字的区别。 #### 1. ...
本文总结了 ORACLE 中 SQL 语句优化的十个要点,旨在提高 SQL 语句的执行效率和性能。 1. 选择最有效率的表名顺序 在基于规则的优化器中,ORACLE 的解析器按照从右到左的顺序处理 FROM 子句中的表名。如果有多个表...
本文将详细介绍 Oracle 中提高 SQL 查询效率的技巧和策略,包括选择最有效率的表名顺序、WHERE 子句中的连接顺序、SELECT 子句中避免使用‘*’、减少访问数据库的次数、使用 DECODE 函数、整合简单的数据库访问、...
本文将详细介绍几种有效的方法来提高Oracle中SQL的执行效率,包括选择合适的表名顺序、优化WHERE子句中的连接顺序、减少不必要的数据库访问等策略。 #### 1. 选择最有效率的表名顺序 在基于规则的优化器中,Oracle...
本文总结了 30 多条 Oracle 数据库优化的经验,涵盖了选择最有效率的表名顺序、WHERE 子句中的连接顺序、SELECT 子句中避免使用 ‘*‘、减少访问数据库的次数、使用 DECODE 函数来减少处理时间、整合简单、无关联的...
在基于规则的优化器中,Oracle 的解析器按照从右到左的顺序处理 FROM 子句中的表名。因此,在 FROM 子句中写在最后的表(基础表)将被最先处理。在 FROM 子句中包含多个表的情况下,需要选择记录条数最少的表作为...
10. **用WHERE子句替换HAVING子句**:WHERE子句在数据检索之前执行,而HAVING子句在聚合后过滤结果。尽可能使用WHERE以减少计算成本,尤其是在无需计算字段过滤的情况下。 在多表联接查询中,ON、WHERE和HAVING的...
在 Oracle 中,解析器按照从右到左的顺序处理 FROM 子句中的表名。因此,在 FROM 子句中写在最后的表(基础表 driving table)将被最先处理。在 FROM 子句中包含多个表的情况下,必须选择记录条数最少的表作为基础表...
3. 优化WHERE子句和HAVING子句:在编写SQL查询语句时,应当优先使用WHERE子句而不是HAVING子句。WHERE子句在查询时依次选择记录,而HAVING子句则是在分组之后对组进行操作,因此WHERE子句的效率更高。 通过对上述...
Oracle自下而上解析WHERE子句,因此表之间的连接条件应位于其他WHERE条件之前,且应将过滤掉最多记录的条件置于WHERE子句的末尾,以尽早剔除不满足条件的记录,减少后续处理的开销。 #### SELECT子句避免使用通配符...
10. **用WHERE子句替换HAVING子句**:WHERE子句在数据检索前过滤记录,而HAVING在聚合操作后过滤,因此在可以提前过滤的情况下,使用WHERE子句更高效。 这些优化策略是针对Oracle SQL语句进行性能提升的基本方法。...
本文将详细介绍 Oracle SQL 语句多表关联查询的知识点,包括字符串和数字的比较、分组查询、HAVING 子句、查询顺序、Oracle 中的伪列、子查询和表连接等。 一、字符串和数字的比较 在 Oracle 中,字符串和数字可以...
10. **Where子句优于Having子句**:在可能的情况下,使用WHERE子句替换HAVING子句,因为在数据检索后过滤数据会增加额外的处理负担。HAVING用于分组后的过滤,而WHERE在分组前过滤。 11. **减少对表的查询**:尽量...
2. **WHERE子句中的连接顺序**:Oracle解析WHERE子句时,从下到上进行。应将能够过滤最多记录的条件放在最后,以尽早减少数据量。 3. **SELECT子句避免使用通配符‘*’**:使用‘*’会导致Oracle解析所有列,增加...
1. **WHERE子句与HAVING子句的区别**: WHERE子句用于筛选满足特定条件的行,而HAVING子句则在GROUP BY之后对分组后的数据进行过滤。在问题1中,如果想限制只包含收入超过15000的雇员,应使用HAVING子句,因为WHERE...
总之,《Pro Oracle SQL》中的这一章节深入介绍了`HAVING`子句的用法,帮助读者掌握如何在Oracle数据库环境中有效地进行分组和条件筛选,提升SQL查询的灵活性和实用性。通过实践和理解提供的示例脚本,读者将能够将...
* 将过滤条件尽可能放到 Where 子句中,而不是放到 Having 子句中 * 在 SQL 语句中,要减少对表的查询,特别是在含有子查询的 SQL 子句中 * 使用表的别名可以减少解析的时间并避免引起歧义 * 使用 exists 替代 in * ...