【mysql】查询过滤器ON,WHERE,HAVING

31 篇文章 88 订阅
执行顺序:
首先是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执行后的结果将一样。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值