如何选择与具有MAX(列)值的行区分另一列引用。 这是我的表:
Category | Desc | Total1 | Total2 | MaxDate | Topic
--------------------------------------------------------
A | A Desc | 1 | 3 | 2017-04-01 | Topic1
A | A Desc | 1 | 1 | 2017-05-10 | Topic2
B | B Desc | 1 | 1 | 2017-03-25 | Topic3
我想从Topic
列中选择MaxDate
列作为参考最大值。我希望表格像:
Category | Desc | Total1 | Total2 | MaxDate | Topic
--------------------------------------------------------
A | A Desc | 2 | 4 | 2017-05-10 | Topic2
B | B Desc | 1 | 1 | 2017-03-25 | Topic3
然后Total1
和Total2
是来自SUM行的值具有不同的
答案 0 :(得分:2)
以这种方式基于您的数据我们也可以实现
Declare @Table1 TABLE
(Category varchar(1), Descp varchar(6), Total1 int, Total2 int, MaxDate datetime, Topic varchar(6))
;
INSERT INTO @Table1
(Category, Descp, Total1, Total2, MaxDate, Topic)
VALUES
('A', 'A Desc', 1, 3, '2017-04-01 00:00:00', 'Topic1'),
('A', 'A Desc', 1, 1, '2017-05-10 00:00:00', 'Topic2'),
('B', 'B Desc', 1, 1, '2017-03-25 00:00:00', 'Topic3')
;
SCRIPT
Select TT.Category,
TT.Descp,
TT.Total1,
TT.Total2,
TT.MaxDate,
T.Topic
From @Table1 T
INNER JOIN (
select
Category,Descp,
SUM(Total1)Total1,
SUM(Total2)Total2,
Max(MaxDate)MaxDate
from @Table1
GROUP BY Category,Descp )TT
ON T.MaxDate = TT.MAXDATE
答案 1 :(得分:1)
使用可以像这样使用row_number和sum() over()
DECLARE @SampleData AS TABLE
(
Category varchar(10), [Desc] varchar(20), Total1 int, Total2 int, MaxDate datetime, Topic varchar(10)
)
INSERT INTO @SampleData VALUES
('A','A Desc', 1, 3, '2017-04-01', 'Topic1'),
('A','A Desc', 1, 1, '2017-05-10', 'Topic2'),
('B','B Desc', 1, 1, '2017-03-25', 'Topic3')
;WITH temp AS
(
SELECT sd.Category, sd.MaxDate, sd.Topic, sd.[Desc],
row_number() OVER(PARTITION BY sd.Category ORDER BY sd.MaxDate desc) AS Rn,
Sum(sd.Total1) OVER(PARTITION BY sd.Category ) AS Total1,
Sum(sd.Total2) OVER(PARTITION BY sd.Category ) AS Total2
FROM @SampleData sd
)
SELECT t.Category, t.[Desc], t.Total1,t.Total2, t.MaxDate, t.ToPic
FROM temp t
WHERE t.Rn = 1