如何在SQL中选择DISTINCT另一列,按行MAX(列值)

时间:2017-05-10 02:59:08

标签: sql-server inner-join self-join

如何选择与具有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

然后Total1Total2是来自SUM行的值具有不同的

2 个答案:

答案 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_numbersum() 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

演示链接:http://rextester.com/NQI25173