Oracle学习日志-7(聚合查询)

GROUP BY子句:

GROUP BY可以对表进行分割。比如把下面的表按照商品种类进行分割,并列出该商品种类下有多少商品

SQL代码如下

SELECT product_type ,COUNT(*)
FROM Product
GROUP BY product_type;


或者按商品种类分类,然后求出该商品种类下的商品售价一共多少钱。

SELECT product_type ,SUM(sale_price)
FROM Product
GROUP BY product_type;


这里GROUP BY子句指定的列称为聚合键,GROUP BY product_type中,聚合键就是product_type。如果聚合键中包含NULL,也会将NULL作为一组特定的数据。
比如以进价作为聚合键:

SELECT purchase_price ,COUNT(*)
FROM Product
GROUP BY purchase_price;


查询结果表示,进价为NULL的记录有2条,进价为500的记录有2条,进价为790的记录有1条,进价为2800的记录有2条,进价为320的记录有1条。


HAVING子句:

HAVING子句可以为分组后的表指定条件,同样,WHERE也可以指定条件,但是WHERE只能指定记录的条件,HAVING可以指定组的条件。
HAVING子句格式

SELECT <列名1> <列名2> <列名3>......
FROM<表名>
GROUP BY <列名1> <列名2> <列名3>
HAVING<分组结果对应条件>

例如按照商品种类分组,然后取出分组后记录为2的种类。

SELECT product_type ,COUNT(*)
FROM Product
GROUP BY product_type
HAVING COUNT(*)=2;


或者是查询按照商品种类分组,然后列出分组下,售价平均值大于2000的记录

SELECT product_type ,AVG(sale_price)
FROM Product
GROUP BY product_type
HAVING AVG(sale_price)>2000;

转载于:https://my.oschina.net/u/4000133/blog/3005171

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值