Oracle SQL Query Получите оставшуюся сумму по группам

Мне нужно найти оставшуюся сумму для каждого кредита. Ожидаемый результат:

CREDIT_NO   CREDIT_TYPE CREDIT_AMOUNT   TOTAL_A REMAINING_AMT   FINAL_TOTAL_PER_BILL
A1          W           100             1000     900            600
A1          X           100             1000     800            600
A1          Y           100             1000     700            600
A1          Z           100             1000     600            600
B1          X           100             2000     1900           1700
B1          Y           100             2000     1800           1700
B1          Z           100             2000     1700           1700

Вот запрос, который я сделал до сих пор (прошу прощения за нуб):

WITH TEMP AS
  (SELECT 1 ID,
    'A1' CREDIT_NO,
    'X' CREDIT_TYPE,
    100 CREDIT_AMOUNT,
    1000 TOTAL_A
  FROM DUAL
  UNION ALL
  SELECT 2, 'A1' , 'Y', 100, 1000 FROM DUAL
  UNION ALL
  SELECT 4, 'A1' , 'Z', 100, 1000 FROM DUAL
  UNION ALL
  SELECT 3, 'B1', 'X', 100, 2000 FROM DUAL
  UNION ALL
  SELECT 5, 'B1', 'Y', 100, 2000 FROM DUAL
  UNION ALL
  SELECT 6, 'B1', 'Z', 100, 2000 FROM DUAL
  UNION ALL
  SELECT 7, 'A1', 'W', 100, 1000 FROM DUAL
  )

SELECT 
  TEMP1.CREDIT_NO ,
  TEMP1.CREDIT_TYPE,
  TEMP1.CREDIT_AMOUNT ,
  TEMP1.TOTAL_A ,
  CASE
    WHEN TEMP1.CREDIT_NO  = (LAG (TEMP1.CREDIT_NO,1) OVER (ORDER BY TEMP1.CREDIT_NO) ) -- set remaining CREDIT_AMOUNT
    OR (LAG (TEMP1.CREDIT_NO,1) OVER (ORDER BY TEMP1.CREDIT_NO) ) IS NULL
    THEN TEMP1.TOTAL_A - (SUM(TEMP1.CREDIT_AMOUNT) OVER ( ORDER BY TEMP1.CREDIT_NO ROWS BETWEEN
      UNBOUNDED PRECEDING
    AND CURRENT ROW ) )
    WHEN TEMP1.CREDIT_NO <>   -- new bill, new total CREDIT_AMOUNT
      (LAG (TEMP1.CREDIT_NO,1) OVER (ORDER BY TEMP1.CREDIT_NO) )
    THEN TEMP1.TOTAL_A - TEMP1.CREDIT_AMOUNT
  END AS REMAINING_AMT 
  ,TEMP1.TOTAL_A - (SUM(TEMP1.CREDIT_AMOUNT) OVER (PARTITION BY CREDIT_NO)) AS FINAL_TOTAL_PER_BILL
FROM TEMP TEMP1
ORDER BY CREDIT_NO, CREDIT_TYPE

Моя проблема заключается в том, что я не знаю, как вычислить оставшуюся сумму для второго кредита. Результатом вышеуказанного запроса является:

CREDIT_NO   CREDIT_TYPE CREDIT_AMOUNT   TOTAL_A REMAINING_AMT   FINAL_TOTAL_PER_BILL
A1          W           100             1000     900            600
A1          X           100             1000     800            600
A1          Y           100             1000     700            600
A1          Z           100             1000     600            600
B1          X           100             2000     1900           1700
B1          Y           100             2000     1400           1700
B1          Z           100             2000     1300           1700

Возможно ли получить оставшуюся сумму без использования хранимой процедуры? Я пытался использовать его на rownum, но он не последователен.

Несмотря на то, что я нашел похожие вопросы к этому ( Ссылка 1 , Ссылка 2 , Ссылка 3 ) (Я все еще перебираю третью ссылку), надеюсь, вы, ребята, можете мне помочь.

2
nl ja de

1 ответы

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

select credit_no, credit_type, 
   total_a - sum(credit_amount) over (partition by credit_no order by id) as remaining_credit,
   total_a,
   total_a - sum(credit_amount) over (partition by credit_no) as FINAL_TOTAL_PER_BILL
from temp 

см. sqlfiddle

2
добавлено
Я рад, это полезно. Английский не мой основной язык, и я только что выбрал неправильное слово. «Будьте осторожны», я имел в виду «обращать внимание», «видеть разницу на», «выбирать раздел строго» :)
добавлено автор Florin Ghita, источник
О, МОЙ БОГ! Это прекрасно работает. Спасибо за помощь. Но что вы имеете в виду, будучи осторожным?
добавлено автор ASC, источник
SqlCom.ru - Стиль жизни SQL
SqlCom.ru - Стиль жизни SQL
908 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только MS SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz). Предложения в @sql_ninja

SQL_Ninja
SQL_Ninja
340 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz)

Oracle RU
Oracle RU
303 участник(ов)

Русскоязычная группа по Oracle. — Архитектура СУБД — PL/SQL — Оптимизация — Администрирование — Вакансии Oracle (указать инфу по вилке ЗП и удалёнке) Приглашайте коллег :-) Запрещены: личные оскорбления, обсуждения оффтопик вопросов политики и религии