【mysql】查询过滤器ON,WHERE,HAVING
2013-01-28 15:11
274 查看
执行顺序:
首先是ON,接着是WHERE, 接着是HAVING。
用法:
ON : 在进行多表的连接查询时,才会用到on来过滤。ON首先会把不符合查询条件的数据给过滤掉,从而减少了查询过程中数据运算的次数。
WHERE :在查询得到临时表后,在数据计算之前执行。由于数据还没分组和进行列的选取操作,
因此不能应用where的情况有:(1)使用列的别名,如select name as n from tb where n='xiaohua';
(2)使用统计方法(MIN,MAX,SUM等),如select *,id from tb where count(id) <2;
HAVING :只有在使用group by后,having操作才有意义。having在数据计算之后执行。
小结:
(1)多表连接查询情况下用on过滤。
(2)单表查询情况下,如果select的字段没有涉及到计算过程,where和having执行后的结果将一样。
首先是ON,接着是WHERE, 接着是HAVING。
用法:
ON : 在进行多表的连接查询时,才会用到on来过滤。ON首先会把不符合查询条件的数据给过滤掉,从而减少了查询过程中数据运算的次数。
WHERE :在查询得到临时表后,在数据计算之前执行。由于数据还没分组和进行列的选取操作,
因此不能应用where的情况有:(1)使用列的别名,如select name as n from tb where n='xiaohua';
(2)使用统计方法(MIN,MAX,SUM等),如select *,id from tb where count(id) <2;
HAVING :只有在使用group by后,having操作才有意义。having在数据计算之后执行。
小结:
(1)多表连接查询情况下用on过滤。
(2)单表查询情况下,如果select的字段没有涉及到计算过程,where和having执行后的结果将一样。
相关文章推荐
- MySQL查询之ON,WHERE,HAVING
- 【mysql】【查询的五种语法where、group by、having、order by、limit】
- mysql中left join on后面and和where条件查询的差异
- mysql group by内排序的实现以及having和where 条件语句查询的区别
- mysql 区间查询,替换,自增,where与having区分,字段运算,关键词搜索等
- Mysql之查询、where、常用函数、having
- sql查询条件on where having 介绍
- mysql查询什么时候用on什么时候用where?
- MySql学习(二) —— where / having / group by / order by / limit 简单查询
- mysql left( right ) join使用on 与where 筛选的差异 博客分类: mysql MySQLSQL数据结构 有这样的一个问题mysql查询使用mysql中left(
- Mysql中Group By使用Having语句配合查询(where和having区别)
- 记一次子查询优化,where与having优先级问题
- MySQL 自学笔记之:数据库查询 DQL(Data Query Lanuage)数据分类(where 子语句)
- MySQL left join操作中 on与where放置条件的区别
- 当一个查询语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序
- 警惕 MySql 更新 sql 的 WHERE 从句中的 IN() 子查询时出现的陷阱
- MySQL的left join中on与where的区别
- Mysql关于join on where(and)的区别
- mysql中的where和having子句的区别
- SQL 查询条件放在LEFT OUTER JOIN 的ON语句后与放在WHERE中的区别