GROUP BY 和 HAVING 子句(看完就会)

GROUP BY 和 HAVING 子句用于对查询结果进行分组和过滤,它们通常一起使用,但也可以单独使用。

GROUP BY 子句:

  • GROUP BY 子句用于将查询结果根据一个或多个列进行分组
  • 它将具有相同分组列值的行组合在一起,形成一个组。
  • GROUP BY 子句通常与聚合函数(如 SUMAVGCOUNTMAXMIN)一起使用,以便对每个组进行计算。

语法:

SELECT column1, column2, ...
FROM table_name
WHERE condition
GROUP BY column1, column2, ...;

示例:

SELECT customer_city, COUNT(*) AS total_customers
FROM customers
GROUP BY customer_city;

假设 customers 表数据如下:

customer_idcustomer_namecustomer_city
1张三Beijing
2李四Shanghai
3王五Shanghai
4赵六Beijing
5孙七Shenzhen

返回结果:

customer_citytotal_customers
Beijing2
Shanghai2
Shenzhen1

 按 customer_city 列分组,并统计每个城市中的客户数量

HAVING 子句:

  • HAVING 子句用于过滤分组后的结果集
  • 它类似于 WHERE 子句,但 HAVING 子句用于过滤组,而 WHERE 子句用于过滤行。
  • HAVING 子句通常与聚合函数一起使用,以便对组进行过滤。

语法:

SELECT column1, column2, ...
FROM table_name
WHERE condition
GROUP BY column1, column2, ...
HAVING condition;

示例:

SELECT customer_city, COUNT(*) AS total_customers
FROM customers
GROUP BY customer_city
HAVING COUNT(*) > 1;

返回结果:

customer_citytotal_customers
Beijing2
Shanghai2

 按 customer_city 列分组,并统计每个城市中的客户数量,只返回客户数量大于 1 的城市

SELECT order_date, COUNT(*) AS total_orders
FROM orders
GROUP BY order_date
HAVING COUNT(*) > 2;

假设 orders 表数据如下:

order_idorder_datecustomer_id
1012023-03-011
1022023-03-012
1032023-03-013
1042023-03-024
1052023-03-025
1062023-03-036

返回结果:

order_datetotal_orders
2023-03-013

 按 order_date 列分组,并统计每个日期的订单数量,只返回订单数量大于 2 的日期

总结:

  • GROUP BY 子句用于将查询结果进行分组,以便对每个组进行计算。
  • HAVING 子句用于过滤分组后的结果集,以便只返回符合条件的组。
  • GROUP BY 和 HAVING 子句通常一起使用,但也可以单独使用。

注意:

  • HAVING 子句必须放在 GROUP BY 子句之后。
  • 在 HAVING 子句中可以使用聚合函数,但在 WHERE 子句中不能使用聚合函数。

求点赞!!!求点赞!!!求点赞!!!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值