我有一个挑战,我在多个场合都遇到过,但从来没有找到有效的解决方案。想象一下,我有一个大表,其中包含有关银行账户及其可能的从借方到贷方的循环移动的数据:
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)上运行的解决方案会很好。
正如您可以想象的那样,无法判断是否只有借记或贷记行,或者帐户是否每天都在循环。