2017-11-14 2 views
0

rowcount별로 내 테이블 데이터 순위를 그룹화하려고합니다. 각 ProductID에 대해 날짜순으로 정렬 된 처음 12 개의 행은 값 = 1을가집니다. 다음 12 개의 행은 값 = 2가 할당되는 식으로 계속됩니다.행 번호 기반 순위 SQL Server 2008 R2

테이블 구조가 보이는 방법 :

For ProductID = 1267 are below associated dates: 
02-01-2016 
03-01-2016 
. 
. (skipping months..table has one date per month) 
. 
12-01-2016 
02-01-2017 
. 
. 
. 
02-01-2018 
+0

> 12) 그냥 생각, 또한 테이블 이름과 날짜 열 이름은 무엇입니까 –

답변

1

사용 row_number() over()을 (제품 ID 당) 날짜별로 정렬 (12)의 그룹을 계산하기 위해 몇 가지 산술. 필요에 맞게 정렬을 ASCendng 또는 DESCendng로 변경하십시오.

select * 
, (11 + row_number() over(partition by productid order by somedate DESC))/12 as rnk 
from mytable 
GO 
 
myTableID | productid  | somedate   | rnk 
--------: | :------------- | :------------------ | :-- 
     9 | 123456   | 2018-11-12 08:24:25 | 1 
     8 | 123456   | 2018-10-02 12:29:04 | 1 
     7 | 123456   | 2018-09-09 02:39:30 | 1 
     2 | 123456   | 2018-09-02 08:49:37 | 1 
     1 | 123456   | 2018-07-04 12:25:06 | 1 
     5 | 123456   | 2018-06-06 11:38:50 | 1 
     12 | 123456   | 2018-05-23 21:12:03 | 1 
     18 | 123456   | 2018-04-02 03:59:16 | 1 
     3 | 123456   | 2018-01-02 03:42:24 | 1 
     17 | 123456   | 2017-11-29 03:19:32 | 1 
     10 | 123456   | 2017-11-10 00:45:41 | 1 
     13 | 123456   | 2017-11-05 09:53:38 | 1 
     16 | 123456   | 2017-10-20 15:39:42 | 2 
     4 | 123456   | 2017-10-14 19:25:30 | 2 
     20 | 123456   | 2017-09-21 21:31:06 | 2 
     6 | 123456   | 2017-04-06 22:10:58 | 2 
     14 | 123456   | 2017-03-24 23:35:52 | 2 
     19 | 123456   | 2017-01-22 05:07:23 | 2 
     11 | 123456   | 2016-12-13 19:17:08 | 2 
     15 | 123456   | 2016-12-02 03:22:32 | 2 

dbfiddle here

당신은 샘플 데이터의 5 개 이상의 행을 ... (가장 작은 고장이 12 인 경우는 조금 있어야 할 수 있습니다