首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >只有当状态符合标准时才选择客户id

只有当状态符合标准时才选择客户id
EN

Stack Overflow用户
提问于 2022-02-28 18:48:24
回答 1查看 45关注 0票数 0

我正试着从数据库中提取一些记录。在大多数情况下,我需要高水平的细节。但是,如果状态为3,则需要提取客户级别的信息。

它看起来像这样。然而,到目前为止,案例陈述似乎不起作用。

代码语言:javascript
复制
SELECT
    product as product,
    state as state,
    CASE WHEN state = 3 THEN customers ELSE 0 END as customerid,
    SUM(sales)
FROM database
GROUP BY
    product,
    state,
    CASE WHEN state = 3 THEN customers ELSE 0 END

我可以删除case语句,并提取每个州的客户编号。然而,回报太大了。我认为这将是理想的,只要得到客户号码,它是必需的,而在情况下,它是不需要的,我只是得到一个0。从而减小了输出的大小。

欢迎对最佳实践的任何帮助。

Oracle sql

EN

回答 1

Stack Overflow用户

发布于 2022-03-01 10:25:54

我只想把这两个总数结合起来:

代码语言:javascript
复制
SELECT product as product,
       state as state,
       customers AS customerid,
       SUM(sales)
  FROM DATABASE
 WHERE state = 3
 GROUP BY product, state, customers
 UNION
SELECT product as product,
       state as state,
       0 AS customerid,
       SUM(sales)
  FROM DATABASE
 WHERE NVL(state,0) <> 3
 GROUP BY product, state;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71299688

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档