Вот мои данные

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

Если я сделаю

SELECT sum(EMISSION) from table where POLLUTANT = 'A' group by COUNTYID;

Я бы получил загрязнение от загрязнителя «А». Как я могу написать запрос, чтобы получить следующие данные:

Столбец 1 с суммой A, столбец 2 с суммой B, столбец 3 с суммой A и B?

Спасибо

sql
2
Jiaoyan Huang 2 Мар 2018 в 17:45

4 ответа

Лучший ответ

Вы можете использовать регистр для фильтрации нужного значения

  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
scaisEdge 2 Мар 2018 в 14:51

Вы можете использовать условную агрегацию. Это перемещает условия фильтрации из условия where в sum() s:

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
Gordon Linoff 2 Мар 2018 в 14:52

Вы должны использовать case case:

SELECT 
 SUM( CASE WHEN POLLUTANT = 'A' THEN EMISSION ELSE 0 END) AS A_EMISSION
 SUM( CASE WHEN POLLUTANT = 'B' THEN EMISSION ELSE 0 END) AS B_EMISSION
 SUM(EMISSION) AS total_emission
FROM table 
GROUP BY COUNTYID;
0
sia 2 Мар 2018 в 21:25

Я хотел бы дать некоторую идею. Мы можем использовать сводную таблицу для ответа на ваш вопрос

SELECT * from  dbo.[Table_1]
PIVOT
(Sum([type_emmssion]) for [polutant] in ([A], [B]) ) as PivotTable
 group by  [CountryId]  ;
0
Anusha Subashini 2 Мар 2018 в 21:12