Как получить результаты SQL на основе года? - PullRequest
0 голосов
/ 24 мая 2018

Пример:

Таблица:

+---+----+----+----+
| id|year|  A |  B |
+---+----+----+----+
|101|2017| 50 | 40 |
|102|2017| 40 | 45 |
|103|2017| 80 | 15 |
|104|2017| 0  | 0  |
|101|2018| 65 | 75 |
|102|2018| 50 | 40 |
|103|2018| 25 | 55 |
|104|2018| 0  | 0  |
+---+----+----+----+

* Данные за следующий год и т. Д. Будут добавлены в таблицу

Таким образом, на основе приведенной выше таблицы, Я хочу, чтобы результаты были такими:

+---+--------------+--------------+-------------+
| id|Total for 2017|Total for 2018|Overall Total|
+---+--------------+--------------+-------------+
|101|     90       |     140      |    230      |
|102|     85       |     90       |    175      |
|103|     95       |     80       |    175      |
+---+--------------+--------------+-------------+

Показывать только идентификатор, что общая сумма не равна нулю.

Есть ли запрос, который я могу получить результаты, как указано выше?

Ответы [ 3 ]

0 голосов
/ 24 мая 2018
select id,
       sum(case when year = 2017 then a+b else 0 end) as [2017],
       sum(case when year = 2018 then a+b else 0 end) as [2018],
       sum(a+b) as Total
from your_table
group by id
having sum(a+b) > 0
0 голосов
/ 24 мая 2018

Привет, вы можете использовать Pivot для обработки более динамических данных.См. Пример ниже для определения номера года и динамических лет.Попробуйте один раз.

CREATE TABLE #yt 
( [id] int, [year] int,  [a] int,[b] int);
INSERT INTO #yt 
VALUES(101,2017,50,40),(102,2017,40,45),(103,2017,80,15)
     ,(104,2017,0,0),(101,2018,65,75),(102,2018,50,40)
     ,(103,2018,25,55),(104,2018,0,0)

 select *,[2017]+[2018] total from
 (select [id],[year],[a]+[b] as [total] from #yt)
 a1
 pivot
 (sum([total])
 for [year] in ([2017],[2018])
 ) piv

 DECLARE @cols AS NVARCHAR(MAX),
 @query  AS NVARCHAR(MAX)
 set  @cols = stuff((select ',' + QUOTENAME([year] ) from #yt group by 
 [year] order by [year] for xml path('')),1,1,'')

 set @query = ' select *,'+ replace(@cols,',','+') +' total from 
 (select [id],[year],[a]+[b] as [total] from #yt)
 a1
 pivot
 (sum([total]) for [year] in ('+@cols+')) piv'
 EXECUTE sp_executesql  @query 
 drop table   #yt 
0 голосов
/ 24 мая 2018

Самый простой способ - использовать conditional aggregation:

SELECT id
   ,SUM(CASE WHEN year=2017 THEN A+B ELSE 0 END) AS Total_for_2017
   ,SUM(CASE WHEN year=2018 THEN A+B ELSE 0 END) AS Total_for_2018
   ,SUM(A+B) AS Overall_Total
FROM tab
GROUP BY id;

Если A или B могут быть обнуляемыми, вы должны обернуть их в ISNULL.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...