首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL中两个不同组的条件聚合

SQL中两个不同组的条件聚合
EN

Stack Overflow用户
提问于 2018-03-02 22:45:01
回答 4查看 64关注 0票数 2

这是我的数据

代码语言:javascript
复制
COUNTYID POLLUTANT TYPE EMISSION
1        A         1  
1        A         2
1        B         1
1        B         2
2        A         1
2        A         2  
2        B         1 
2        B         2
3        A         1
3        A         2
3        B         1 
3        B         2

如果我这样做了

代码语言:javascript
复制
SELECT sum(EMISSION) from table where POLLUTANT = 'A' group by COUNTYID;

我会受到污染物'A‘的污染。如何编写查询来获取以下数据:

第一列是A的和,第二列是B的和,第三列是A和B的和?

谢谢你

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2018-03-02 22:51:08

你可以用案例来过滤你需要的值

代码语言:javascript
复制
  select COUNTYID, sum(case when POLLUTANT='A'then EMISSION else 0 END)  tot_a
   , sum(case when POLLUTANT='B'then EMISSION else 0 END)  tot_b
   , sum(EMISSION)  tot_a_b
  from my_table 
  group by COUNTYID
票数 1
EN

Stack Overflow用户

发布于 2018-03-02 22:52:46

您可以使用条件聚合。这会将过滤条件从where子句移动到sum()

代码语言:javascript
复制
select countyid,
       sum(case when emission = 'A' then emission else 0 end) as A,
       sum(case when emission = 'B' then emission else 0 end) as B,
       sum(emission) as total
from t
group by countyid;
票数 1
EN

Stack Overflow用户

发布于 2018-03-03 05:12:40

我想给出一些想法。我们可以使用数据透视表来回答您的问题

代码语言:javascript
复制
SELECT * from  dbo.[Table_1]
PIVOT
(Sum([type_emmssion]) for [polutant] in ([A], [B]) ) as PivotTable
 group by  [CountryId]  ;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49071453

复制
相关文章

相似问题

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