SQL查询中having和where的异同点

SQL查询中having与where 的异同点

在sql查询中, having与where类似,可以筛选数据,where后的表达式怎么写,having后就怎么写。
1. where针对表中的列发挥作用,查询数据。
2. having对查询结果中的列发挥作用,筛选数据。

-- 查询本店商品价格比市场价低多少钱,输出低200元以上的商品
select goods_id,good_name,market_price - shop_price as s 
from goods 
having s>200 ;
--这里不能用where因为s是查询结果,而where只能对表中的字段名筛选

如果用where的话则是:

select goods_id,goods_name 
from goods 
where market_price - shop_price > 200;

同时使用where与having

 select cat_id,goods_name,market_price - shop_price as s 
 from goods 
 where cat_id = 3 
 having s > 200;

查询积压货款超过2万元的栏目,以及该栏目积压的货款

    select cat_id,sum(shop_price * goods_number) as s 
    from goods  
    group by cat_id  
    having s > 20000 

查询两门及两门以上科目不及格的学生的平均分
思路:

-- 先计算所有学生的平均分
select name,avg(score) as pj 
from stu 
group by name;
-- 查出所有学生的挂科情况
select name,score<60 
from stu;
-- 这里score<60是判断语句,所以结果为真或假,mysql中真为1假为0

-- 查出两门及两门以上不及格的学生
select name,sum(score<60) as gk 
from stu 
group by name 
having gk > 1;

-- 综合结果
select name,sum(score<60) as gk,avg(score) as pj 
from stu 
group by name 
having gk >1; 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值