sql笔记

1、----------------------where和having------------------------

2、where

      where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚合函数,使用where条件显示特定的行。

 

3、having

      having子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚合函数,使用having条件显示特定的组,也可以使用多个分组标准进行分组。

      having子句被限制于已经在select语句中定义的列和聚合表达式上。通常,你需要通过在having子句中重复聚合函数表达式来引用聚合值,就如你在select语句中做的那样。

 

☆:having子句和where有相似之处:都是设定条件的语句。

       但是二者也有区别:

       在查询过程中聚合语句(sum,min,max,avg,count)要比having子句优先执行。而where子句在查询过程中执行优先级别优先于聚合语句。

  

      简单来说:

      where子句:select sum(num) as rmb from order where id > 10; //只有先查询出id大于10的记录才能进行聚合语句

      having子句:select reportsto as manager,count(*) as reports from employees group by reportsto having count(*) > 4; //having子句查询过程执行优先级别低于聚合语句。

 

      换句话说:

      把上面的having换成where则会出错。统计分组数据时用到聚合语句。对分组数据再次判断时要用having。如果不用这些关系就不存在使用having。直接使用where就行了。

      having就是用来弥补where在分组数据判断时的不足。因为where执行优先级别要快于聚合函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值