Выбирать только строки, где seqnum - это специфицированное c значение - PullRequest
0 голосов
/ 11 июля 2020

У меня есть следующий сценарий, как мне включить только строки, где seqnum = 1. В настоящее время все отображается, и мне нужны только строки, в которых [LongName] уникально. Я не могу поместить предложение WHERE вокруг seqnum, он не распознает столбец.

SELECT [LongName]
     , [InstanceId]
     , [Number]   
     , [Value]
     , [Employee]
     , [Time]
     , DENSE_RANK() over (partition by [LongName] order by [Time] desc) as seqnum 
FROM [DataValue]
INNER JOIN [NumberPlate] ON DataValueId = NumberPlate.Id
WHERE [Number] LIKE '%55AA0%' AND [Employee]=1 
ORDER BY [Time] DESC

что делает мой запрос

InstanceID  Number  Value       LongName    Employee    Time    seqnum
40            1      5105.993   Parameter C    1    05:10.0   1
20            1      5117.298   Parameter D    1    05:10.0   1
12            1      5126.925   Parameter E    0    05:10.0   1
46            1      5132.83    Parameter B    4    05:10.0   1
453           1      GG2        Parameter A    0    05:10.0   1
345           1      55D        Parameter B    0    05:09.9   2
234           1      5287.562   Parameter D    1    05:09.9   2
865           1      5310.893   Parameter C    2    05:09.9   2
23            1      5105.993   Parameter B    2    05:09.9   2
245           1      GG3        Parameter A    3    03:57.8   2

что бы я хотел

InstanceID  Number  Value       LongName    Employee    Time    seqnum
40            1      5105.993   Parameter C    1    05:10.0   1
20            1      5117.298   Parameter D    1    05:10.0   1
12            1      5126.925   Parameter E    0    05:10.0   1
46            1      5132.83    Parameter B    4    05:10.0   1
453           1      GG2        Parameter A    0    05:10.0   1

Ответы [ 3 ]

2 голосов
/ 11 июля 2020

Интересный способ сделать это - использовать SELECT WITH TIES:

SELECT TOP (1) WITH TIES [LongName], [InstanceId], [Number]   , [Value], [Employee], [Time]
FROM [DataValue] INNER JOIN
     [NumberPlate]
     ON DataValueId = NumberPlate.Id
WHERE [Number] LIKE '%55AA0%' AND [Employee]=1 
ORDER BY DENSE_RANK() over (partition by [LongName] order by [Time] desc) as seqnum ;

Однако, если вы действительно хотите, чтобы окончательные результаты были упорядочены по time, вам понадобится дополнительный подзапрос.

1 голос
/ 11 июля 2020

Вы также можете использовать CTE, как показано ниже:

;WITH CTE AS (
SELECT [LongName]
      ,[InstanceId]
      ,[Number]   
      ,[Value]
      ,[Employee]
      ,[Time]
      ,DENSE_RANK() OVER (PARTITION BY [LongName] ORDER BY [Time] DESC) AS seqnum
FROM 
   [DataValue]
    INNER JOIN [NumberPlate] ON DataValueId = NumberPlate.Id
WHERE
    [Number] LIKE '%55AA0%' AND [Employee]=1 
)
SELECT *
FROM 
    CTE
WHERE 
    seqnum = 1 
ORDER BY 
    [Time] 
DESC
1 голос
/ 11 июля 2020

Только ваш запрос в подзапросе:

Select * from 
(SELECT [LongName]
      ,[InstanceId]
      ,[Number]   
      ,[Value]
      ,[Employee]
      ,[Time]
       ,DENSE_RANK() over (partition by [LongName] order by [Time] desc) as seqnum 
  
  FROM [DataValue]
  INNER JOIN [NumberPlate]
  On DataValueId = NumberPlate.Id
  
 WHERE [Number] LIKE '%55AA0%' AND [Employee]=1 
  ORDER BY [Time] DESC)
where seqnum = 1;
...