SQL Server Max Value of the Sum of Multiple Columns

2ul0zpep  于 2023-08-02  发布在  其他
关注(0)|答案(2)|浏览(111)

I am using one table in SQL Server.

This is how the table is displayed originally:
| ItemNo | StoreNo | DemandYr1 | DemandYr2 | DemandYr3 |
| ------------ | ------------ | ------------ | ------------ | ------------ |
| 1 | AA | 2 | 3 | 0 |
| 1 | BB | 5 | 1 | 2 |
| 5 | BB | 5 | 5 | 5 |
| 5 | CC | 0 | 0 | 6 |
| 3 | AA | 2 | 1 | 4 |
| 3 | BB | 1 | 0 | 3 |
| 3 | CC | 2 | 2 | 2 |

After using this query,

select itemno, storeno, sum(DemandYr1 + DemandYr2 + DemandYr3) as SumDemand
from ExTable 
group by itemno, storeno
order by itemno asc

I have gotten the table to this:

ItemNoStoreNoSumDemand
1AA5
1BB8
5BB15
5CC6
3AA7
3BB4
3CC6

Now, my desired result is to only show the storeno with the highest SumDemand for each ItemNo in a table like this:

ItemNoStoreNoSumDemand
1BB8
5BB6
3CC6

Since the SumDemand column is not part of the original table and was added by me, I am not sure how to query it to only show the greatest SumDemand for each ItemNo. I understand that if two StoreNo's have the same SumDemand there will be duplicates, that is fine.

** If possible, I would also like to omit any results that = 0. Ex: If an Item No has 0 SumDemand at all stores, I would like to delete. (If this is not possible that is also fine) **

t9eec4r0

t9eec4r01#

You can add a row_number to your select in combination with a CTE.

But you should avoid adding spaces in your column names as the must all be escaped

WITH CTE as (
select [item no], [store no], sum([Demand Yr1] + [Demand Yr2] + [Demand Yr3]) as SumDemand
  ,ROW_NUMBER() OVER(PARTITION BY [Item No] ORDER BY  sum([Demand Yr1] + [Demand Yr2] + [Demand Yr3]) DESC ) rn
from ExTable 
group by [item no], [store no])
  SELECT [item no], [store no],SumDemand
  FROM CTE WHERE rn = 1
order by [item no] asc
item nostore noSumDemand
1BB8
3AA7
5BB15

Fiddle

bf1o4zei

bf1o4zei2#

The way you approach this is to use a windowed count; also here the addition is moved to a cross-apply so it can be re-used.

select itemno, storeno, SumDemand
from (
  select itemno, storeno, Sum(Demand) SumDemand, 
    Row_Number() over(partition by itemno order by Sum(demand) desc) rn
  from t
  cross apply(values(DemandYr1 + DemandYr2 + DemandYr3))d(Demand)
  group by itemno, storeno
)t
where rn = 1
order by itemno;

相关问题