Получить следующую и предыдущую строки данных манипуляций в SQL Server - PullRequest
0 голосов
/ 15 марта 2019

У меня есть данные, подобные приведенному ниже формату в таблице:

Id  EmployeeCode    JobNumber           TransferNo  FromDate    Todate
--------------------------------------------------------------------------
1   127             1.0                  0          01-Mar-19   10-Mar-19
2   127             1.0                  NULL       11-Mar-19   15-Mar-19 
3   127             J-1                  1          16-Mar-19   NULL
4   136             1.0                  0          01-Mar-19   15-Mar-19
5   136             J-1                  1          16-Mar-19   20-Mar-19
6   136             1.0                  2          21-Mar-19   NULL

И я хочу получить такой результат:

Id  EmployeeCode    JobNumber           TransferNo  FromDate    Todate
--------------------------------------------------------------------------
2   127             1.0                  NULL       01-Mar-19   15-Mar-19 
3   127             J-1                  1          16-Mar-19   NULL
4   136             1.0                  0          01-Mar-19   15-Mar-19
5   136             J-1                  1          16-Mar-19   20-Mar-19
6   136             1.0                  2          21-Mar-19   NULL

Идея

  1. Если задание одинаково в непрерывной записи, чем в одной строке с максимальным идентификатором с минимальной и максимальной датами.Например, для сотрудника 127 первый номер задания и номер второго задания одинаковы, а второй и третий ряд различны, затем будут возвращены первый и второй ряды с минимальным значением fromdate и max todate, а третий ряд будет возвращен как есть.

  2. Если номер задания отличается от номера следующего задания, будут возвращены все строки.
    Например: для сотрудника 136: номер первого задания отличается от второго, второй отличается от третьегопоэтому все строки будут возвращены.

Ответы [ 3 ]

1 голос
/ 15 марта 2019

Вы можете группировать по jobNumber и EmployeeCode и использовать Max / Min-Aggregate-Functions для получения желаемых дат

0 голосов
/ 15 марта 2019

Это пример проблемы разрывов и островков. Решением здесь является определение «островков» по ​​их запускам, поэтому процесс выглядит так:

  • определить, когда начинается новая группировка (то есть, нет совпадения с предыдущей строкой)
  • сделать кумулятивную сумму начальных значений для получения значения группировки
  • Совокупный

Это похоже на

select max(id), EmployeeCode, JobNumber,
       min(fromdate), max(todate)
from (select t.*,
             sum(case when fromdate = dateadd(day, 1, prev_todate) then 0 else 1 end) over
                 (partition by EmployeeCode, JobNumber order by id
                 ) as grouping
      from (select t.*,
                   lag(todate) over (partition by EmployeeCode, JobNumber order by id) as prev_todate
            from t
           ) t
     ) t
group by grouping, EmployeeCode, JobNumber;

Неясно, для чего нужна логика TransferNo. Самое простое решение - просто min() или max(), но это не вернет NULL.

0 голосов
/ 15 марта 2019

Я сомневаюсь, что вы получите результат от простых запросов на основе множеств. Итак, мой совет: объявите курсор на SELECT DISTINCT EmployeeCode .... Внутри этого курсора выделите все строки с этим EmployeeCode. Работайте в этом наборе, чтобы выяснить ваши значения и построить набор результатов из этого.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...