温馨提示×

如何在HAVING子句中使用子查询

小樊
86
2024-09-10 00:05:06
栏目: 编程语言

在 SQL 中,HAVING 子句通常与 GROUP BY 子句一起使用,用于过滤满足特定条件的分组

SELECT column_name1, aggregate_function(column_name2)
FROM table_name
GROUP BY column_name1
HAVING aggregate_function(column_name2) IN (
    SELECT aggregate_function(column_name2)
    FROM table_name
    WHERE condition
);

这里是一个具体的例子:

假设我们有一个名为 “orders” 的表格,其中包含以下列:customer_id(顾客ID)、order_date(订单日期)和amount(金额)。

我们希望找到平均消费超过 100 的顾客。首先,我们需要计算每个顾客的平均消费:

SELECT customer_id, AVG(amount) as average_amount
FROM orders
GROUP BY customer_id;

然后,我们可以使用 HAVING 子句和子查询来找到平均消费超过 100 的顾客:

SELECT customer_id, AVG(amount) as average_amount
FROM orders
GROUP BY customer_id
HAVING AVG(amount) > (
    SELECT AVG(amount)
    FROM orders
    WHERE amount > 100
);

这将返回所有平均消费超过 100 的顾客及其平均消费。

0