legongju.com
我们一直在努力
2025-01-13 06:34 | 星期一

如何结合聚合函数使用SQL Case When

在 SQL 中,您可以使用 CASE WHEN 表达式与聚合函数(如 SUM、COUNT、AVG、MAX 和 MIN)结合使用

假设我们有一个名为 “orders” 的表格,其中包含以下列:order_id, customer_id, order_date 和 total_amount。现在,我们想要计算每个客户的平均订单金额,但只考虑订单金额大于 100 的情况。

以下是一个示例查询,展示了如何结合使用 CASE WHEN 和 AVG 聚合函数:

SELECT
    customer_id,
    AVG(CASE WHEN total_amount > 100 THEN total_amount ELSE NULL END) AS average_order_amount
FROM
    orders
GROUP BY
    customer_id;

在这个查询中,我们首先选择 “customer_id” 列。然后,我们使用 AVG 函数计算每个客户的平均订单金额。通过使用 CASE WHEN 表达式,我们可以确保只计算订单金额大于 100 的行。当 total_amount 大于 100 时,我们使用 total_amount 值;否则,我们使用 NULL(表示不计算此行)。最后,我们按 “customer_id” 对结果进行分组。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/105247.html

相关推荐

  • Case When与IF语句在SQL中的区别

    Case When与IF语句在SQL中的区别

    在 SQL 中,CASE WHEN 和 IF 语句都可以用于条件判断,但它们之间有一些关键区别: 语法差异: CASE WHEN 是标准 SQL 语法,适用于多个条件判断。它的语法结构如...

  • SQL Case When语句的嵌套使用技巧

    SQL Case When语句的嵌套使用技巧

    在 SQL 中,CASE WHEN 语句可以帮助我们根据特定条件对数据进行处理 简化多个条件判断: 当有多个条件需要判断时,可以使用嵌套的 CASE WHEN 语句来简化查询。例...

  • 如何使用SQL Case When进行数据转换

    如何使用SQL Case When进行数据转换

    在 SQL 中,CASE WHEN 语句可以让你根据特定条件对数据进行转换
    SELECT column1, column2, CASE WHEN condition1 THEN result1 WHEN condition2 THEN resul...

  • Case When在SQL查询中的实际应用

    Case When在SQL查询中的实际应用

    CASE WHEN 是 SQL 查询中的一个条件表达式,它允许你根据一个或多个条件返回不同的值
    以下是 CASE WHEN 在 SQL 查询中的一些实际应用: 计算学生成绩等级:...

  • SQL Case When语句的语法错误排查

    SQL Case When语句的语法错误排查

    在SQL中,CASE WHEN语句用于在查询中嵌入条件逻辑。如果你遇到了语法错误,可以按照以下步骤进行排查: 确保CASE关键字和WHEN关键字之间有一个空格。
    确保每...

  • SQL Case何时使用When语句

    SQL Case何时使用When语句

    在 SQL 中,CASE 语句用于根据一个或多个条件返回特定的值
    以下是一个使用 CASE 语句和 WHEN 子句的简单示例:
    SELECT CustomerID, FirstName, LastNa...

  • SQL Case When处理空值的方法

    SQL Case When处理空值的方法

    在 SQL 中,CASE WHEN 语句用于根据一个或多个条件返回特定的值
    以下是处理空值的 CASE WHEN 示例:
    SELECT CustomerID, FirstName, LastName, CASE W...

  • 如何使用SQL Update语句进行数据迁移

    如何使用SQL Update语句进行数据迁移

    在 SQL 中,UPDATE 语句用于修改表中的现有数据 首先,确保你有一个目标表和一个源表。例如,我们有两个表:employees_old 和 employees_new。我们想要将 employ...