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

GROUP BY子句:

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

SQL代码以下code

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


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

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


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

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


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


HAVING子句:

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

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;

相关文章
相关标签/搜索