HAVE 语句在 SQL 中主要用于筛选分组后的结果,通常与 GROUP BY 和聚合函数一起使用
- 筛选特定分组:如果你想从分组后的结果中筛选出满足特定条件的分组,可以使用 HAVE 语句。例如,查询销售额超过 1000 的产品类别:
SELECT product_category, SUM(sales) as total_sales FROM sales_data GROUP BY product_category HAVE total_sales > 1000;
- 筛选分组中的行数:当你需要筛选出包含特定数量行的分组时,可以使用 HAVE 语句。例如,查询包含超过 5 个不同客户的销售记录的产品类别:
SELECT product_category, COUNT(DISTINCT customer_id) as unique_customers FROM sales_data GROUP BY product_category HAVE unique_customers > 5;
- 筛选分组中的最大值或最小值:当你需要筛选出包含特定最大值或最小值的分组时,可以使用 HAVE 语句。例如,查询最高销售额超过 500 的产品类别:
SELECT product_category, MAX(sales) as max_sales FROM sales_data GROUP BY product_category HAVE max_sales > 500;
- 筛选分组中的平均值:当你需要筛选出平均值满足特定条件的分组时,可以使用 HAVE 语句。例如,查询平均销售额低于 200 的产品类别:
SELECT product_category, AVG(sales) as avg_sales FROM sales_data GROUP BY product_category HAVE avg_sales < 200;
总之,HAVE 语句在 SQL 中主要用于筛选分组后的结果,帮助你更好地分析和处理数据。