Как получить накопительную сумму в SQL Server - PullRequest
0 голосов
/ 10 июля 2019

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

Это мои данные:

ID     | JO | C. ID  | L |Invoice |Amount |Payment 
279810 | B1 | CL0001 | a | FA0001 | 55638 | 170000
279812 | B1 | CL0001 | a | FA0002 | 40720 | 170000
279814 | B1 | CL0001 | a | FA0003 | 76644 | 170000
279868 | B1 | CL0001 | a | FA0004 | 51500 | 170000

И вот результат, который я хочу:

ID     | JO | C. ID  | L |Invoice |Amount |Payment |Rest   | State
279810 | B1 | CL0001 | a | FA0001 | 55638 | 170000 | 0     | PAID
279812 | B1 | CL0001 | a | FA0002 | 40720 | 170000 | 0     | PAID
279814 | B1 | CL0001 | a | FA0003 | 76644 | 170000 | 3002  | P. PAYMENT
279868 | B1 | CL0001 | a | FA0004 | 51500 | 170000 | 51500 | NOT PAID

Заранее спасибо.

Ответы [ 3 ]

1 голос
/ 10 июля 2019

, чтобы получить совокупную сумму счета, используйте sum(Amount) over (order by ID). Я предположил, что это в порядке ID. Вы также должны разделить с клиентом. Я не включил это в запрос, поскольку я не уверен, каково название столбца для этого

Остальное не так сложно понять. Он использует оператор CASE, чтобы определить, является ли он ОПЛАТНЫМ, ЧАСТИЧНЫМ или НЕ ОПЛАЧЕННЫМ

select  *,
        Rest    = case  when    Payment > sum(Amount) over (order by ID)
                        then    0
                        when    sum(Amount) over (order by ID) - Payment < Amount
                        then    sum(Amount) over (order by ID) - Payment
                        else    Amount
                        end,
        State   = case  when    Payment > sum(Amount) over (order by ID)
                        then    'PAID'
                        when    sum(Amount) over (order by ID) - Payment < Amount
                        then    'P. PAYMENT'
                        else    'NOT PAID'
                        end
0 голосов
/ 10 июля 2019

Вопрос интересный, так как могут быть случаи, когда не будет частичной оплаты, следующий запрос должен делать то, что вы хотите:

CREATE TABLE #temp (ID INT,JO VARCHAR(10),CID VARCHAR(10),L VARCHAR(10), Invoice VARCHAR(10), Amount NUMERIC(10,2), Payment NUMERIC(10,2))
INSERT INTO #temp VALUES
(279810,'B1','CL0001','a','FA0001',55638,170000),
(279812,'B1','CL0001','a','FA0002',40720,170000),
(279814,'B1','CL0001','a','FA0003',73642,170000),
(279868,'B1','CL0001','a','FA0004',51500,170000),
(279868,'B1','CL0001','a','FA0004',200,170000),
(279868,'B1','CL0001','a','FA0004',1234678,170000),
(279868,'B1','CL0001','a','FA0004',90,170000),
(279870,'B1','CL0002','a','FA0005',10000,60000),
(279871,'B1','CL0002','a','FA0006',15000,60000),
(279872,'B1','CL0002','a','FA0007',30000,60000),
(279873,'B1','CL0002','a','FA0008',25000,60000)

SELECT ID,JO,CID,L,Invoice,Amount,Payment
    ,CASE WHEN t.[Balance] >=0 THEN 0 
          WHEN t.[Balance] <0 AND LAG(t.[Balance]) OVER( ORDER BY (SELECT 1)) > 0 THEN ABS(t.[Balance])
          ELSE [Amount] END AS [Balance Amount]
    ,CASE WHEN t.[Balance] >=0 THEN 'Paid'
          WHEN t.[Balance] <0 AND LAG(t.[Balance]) OVER( ORDER BY (SELECT 1)) > 0 THEN 'Partial Payment'
          ELSE 'Not Paid' END AS [Status]
FROM (
    SELECT *
        ,SUM(Amount) OVER (PARTITION BY CID ORDER BY (SELECT 1) ROWS UNBOUNDED PRECEDING ) Cumulative
    FROM #temp ) A
CROSS APPLY (VALUES(Payment - Cumulative)) AS T(Balance)

Результат как ниже,

ID      JO  CID     L   Invoice  Amount     Payment     Balance Amount  Status
279810  B1  CL0001  a   FA0001   55638.00   170000.00   0.00            Paid
279812  B1  CL0001  a   FA0002   40720.00   170000.00   0.00            Paid
279814  B1  CL0001  a   FA0003   73642.00   170000.00   0.00            Paid
279868  B1  CL0001  a   FA0004   51500.00   170000.00   51500.00        Not Paid
279868  B1  CL0001  a   FA0004   200.00     170000.00   200.00          Not Paid
279868  B1  CL0001  a   FA0004   1234678.00 170000.00   1234678.00      Not Paid
279868  B1  CL0001  a   FA0004   90.00      170000.00   90.00           Not Paid
279870  B1  CL0002  a   FA0005   10000.00   60000.00    0.00            Paid
279871  B1  CL0002  a   FA0006   15000.00   60000.00    0.00            Paid
279872  B1  CL0002  a   FA0007   30000.00   60000.00    0.00            Paid
279873  B1  CL0002  a   FA0008   25000.00   60000.00    20000.00        Partial Payment
0 голосов
/ 10 июля 2019

Ну, это хорошо работает для одного клиента, но если у меня несколько клиентов, расчет неверен.

Вот что я получил:

ID     | JO |Customer| L |Invoice |Amount |Payment |Rest   | State
-------+----+--------+---+--------+-------+--------+-------+-------------
279810 | B1 | CL0001 | a | FA0001 | 55638 | 170000 | 0     | PAID
279812 | B1 | CL0001 | a | FA0002 | 40720 | 170000 | 0     | PAID
279814 | B1 | CL0001 | a | FA0003 | 76644 | 170000 | 3002  | P. PAYMENT
279868 | B1 | CL0001 | a | FA0004 | 51500 | 170000 | 51500 | NOT PAID
279870 | B1 | CL0002 | a | FA0005 | 10000 | 60000  | 10000 | NOT PAID
279871 | B1 | CL0002 | a | FA0006 | 15000 | 60000  | 15000 | NOT PAID
279872 | B1 | CL0002 | a | FA0007 | 30000 | 60000  | 30000 | NOT PAID
279873 | B1 | CL0002 | a | FA0008 | 25000 | 60000  | 25000 | NOT PAID

И вот что я должен был получить:

ID     | JO |Customer| L |Invoice |Amount |Payment |Rest   | State
-------+----+--------+---+--------+-------+--------+-------+-------------
279810 | B1 | CL0001 | a | FA0001 | 55638 | 170000 | 0     | PAID
279812 | B1 | CL0001 | a | FA0002 | 40720 | 170000 | 0     | PAID
279814 | B1 | CL0001 | a | FA0003 | 76644 | 170000 | 3002  | P. PAYMENT
279868 | B1 | CL0001 | a | FA0004 | 51500 | 170000 | 51500 | NOT PAID
279870 | B1 | CL0002 | a | FA0005 | 10000 | 60000  | 0     | PAID
279871 | B1 | CL0002 | a | FA0006 | 15000 | 60000  | 0     | PAID
279872 | B1 | CL0002 | a | FA0007 | 30000 | 60000  | 0     | PAID
279873 | B1 | CL0002 | a | FA0008 | 25000 | 60000  | 20000 | P. PAYMENT
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...