У меня есть проблема, с которой я неоднократно сталкивался, но так и не смог найти эффективного решения. Представьте, что у меня есть большая таблица с данными, например, о банковских счетах и их возможных оборотных движениях от дебета к кредиту:
AccountId DebitCredit AsOfDate
--------- ----------- ----------
aaa d 2018-11-01
aaa d 2018-11-02
aaa c 2018-11-03
aaa c 2018-11-04
aaa c 2018-11-05
bbb d 2018-11-02
ccc c 2018-11-01
ccc d 2018-11-02
ccc d 2018-11-03
ccc c 2018-11-04
ccc d 2018-11-05
ccc c 2018-11-06
В приведенном выше примере я хотел бы назначить номера подразделов для комбинации AccountId и DebitCredit, где номер раздела увеличивается каждый раз, когда происходит смещение DebitCredit. Другими словами, в приведенном выше примере я хотел бы получить такой результат:
AccountId DebitCredit AsOfDate PartNo
--------- ----------- ---------- ------
aaa d 2018-11-01 1
aaa d 2018-11-02 1
aaa c 2018-11-03 2
aaa c 2018-11-04 2
aaa c 2018-11-05 2
bbb d 2018-11-02 1
ccc c 2018-11-01 1
ccc d 2018-11-02 2
ccc d 2018-11-03 2
ccc c 2018-11-04 3
ccc d 2018-11-05 4
ccc c 2018-11-06 5
Я не могу понять, как это сделать быстро и эффективно. Операция должна выполняться ежедневно для таблиц с миллионами строк.
В этом примере гарантируется, что у нас будут последовательные строки для всех учетных записей. Однако, конечно, клиент может открыть счет 15 числа в этом месяце и/или закрыть свой счет 26 числа.
Задача должна быть решена на сервере MSSQL 2016, но решение, которое будет работать в 2012 году (и, возможно, даже в 2008r2), было бы неплохо.
Как вы можете себе представить, нет никакого способа узнать, будут ли только дебетовые или кредитные строки или будет ли счет вращаться каждый день.