Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22

Сумма нарастающим итогом

01.07.2022, 11:47. Показов 2223. Ответов 26
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть таблица с продажами по клиентам.
 
id oper_data typ_operation_id Partner sum_acount_cur
1 01.06.22 111 Alfa 100
2 02.06.22 111 Beta 200
3 03.06.22 111 Alfa 150
4 04.06.22 111 Alfa 150
5 05.06.22 111 Beta 120
6 06.06.22 111 Beta 80
7 07.06.22 111 Beta 100
8 08.06.22 111 Beta 300
9 09.06.22 111 Alfa 200
10 10.06.22 111 Beta 100
Нужно получить таблицу с суммами продаж по клиентам по каждой дате с 01.06.22-30.06.22. Причем, если в этот день не было продаж - сумма должна переноситься из предыдущего дня. Последнего не смог добиться.

 
1.6 2.6 3.6 4.6 5.6 6.6 7.6 8.6 9.6 10.6 11.6 12.6 … 30.6
Alfa 100 100 250 400 400 400 400 400 600 600 600 600 600 600
Beta 0 200 200 200 320 400 500 800 800 900 900 900 900 900

Делал так:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
SELECT 
 date_trunc('day',d),
 (SELECT to_char(to_timestamp(to_char((EXTRACT ('day' FROM  date_trunc('day',d))), '999'), 'dd'), 'dd'))AS "man",
 (SELECT CASE WHEN summ IS NULL THEN 0 ELSE summ END) AS summ 
FROM generate_series('01.06.2022','30.06.2022','1 day'::INTERVAL) AS d 
LEFT JOIN 
(
   SELECT date_trunc('day', "operation"."oper_data") AS ts,
   (SELECT to_char(to_timestamp(to_char((EXTRACT ('day' FROM  "operation"."oper_data")), '999'), 'MM'), 'dd'))AS "man", 
 (    
SUM((SELECT CASE WHEN SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=111)IS NULL THEN 0 ELSE SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=111) END -
  CASE WHEN SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=112)*-1 IS NULL THEN 0 ELSE SUM("operation". "sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=112) END)  ) 
  OVER 
(ORDER BY (SELECT CASE WHEN SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=111)IS NULL THEN 0 ELSE SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=111) END -
  CASE WHEN SUM("operation"."sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=112)*-1 IS NULL THEN 0 ELSE SUM("operation". "sum_acount_cur") FILTER (WHERE "operation"."typ_operation_id"=112) END))
 ) 
  AS summ
   
  FROM "public"."operation"
  WHERE 
     AND ("operation"."oper_data" >= '01.01.2001' ::DATE OR "operation"."oper_data" = NULL)
     AND ("operation"."oper_data"<= '30.06.2022' ::DATE OR "operation"."oper_data"= NULL)
  GROUP BY  date_trunc('day', "operation"."oper_data"),man
) AS p ON p.ts=date_trunc('day',d)
За ранее всем благодарен за помощь!
P.S. Подскажите как правильно оформлять таблицу в форуме
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.07.2022, 11:47
Ответы с готовыми решениями:

Запрос с нарастающим итогом
Добрый день, уважаемые форумчане. Может подскажете, как рассчитать значения через нарастающий итог, без курсоров. Есть отсортированная...

Остаток (приход-списано) нарастающим итогом по дате
Привет всем, что то запутался с простым вопросом на mysql. Подскажите пожалуйста как организовать остаток нарастающим итогом. Есть...

Форма с таблицей в которой поле считается нарастающим итогом
Поле СОСТОИТ сущности ДВИЖЕНИЕ должно считаться как СОСТОИТ_ПРЕДЫДУЩЕЕ + ПРИБЫЛО - УБЫЛО и так для каждой записи. Форма должна быть строго...

26
670 / 293 / 120
Регистрация: 12.04.2022
Сообщений: 1,002
06.07.2022, 08:17
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Uminson Посмотреть сообщение
Вопрос в дате. Она везде одинаковая.
Дык, заполните поле таблицы operation.oper_data правильным/универсальным форматом даты

Кликните здесь для просмотра всего текста
Подсказка, например у oktogen даты вывелись нормально
0
0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22
14.07.2022, 12:14  [ТС]
Спасибо, разобрался. Проблема была с датами. Моя невнимательность и пробелы в знаниях.
Еще прошу подсказать как из запроса исключить группировку по "partner"?
Просто убрать
SQL
1
AND p.Partner = o.Partner
не получается. Разваливается весь запрос...
Всем за ранее спасибо!
0
670 / 293 / 120
Регистрация: 12.04.2022
Сообщений: 1,002
14.07.2022, 12:27
Цитата Сообщение от Uminson Посмотреть сообщение
Еще прошу подсказать как из запроса исключить группировку по "partner"?
Цель? Что хочется получить?
0
0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22
14.07.2022, 12:40  [ТС]
Ожидаемый результат
oper_datasum_acount_cur
Apr0
May0
Jun1500
Jul1500
Aug1500

За ранее благодарен!
0
670 / 293 / 120
Регистрация: 12.04.2022
Сообщений: 1,002
14.07.2022, 13:16
Типа такого, допилите по месту.

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
WITH cte (cMonth) AS 
(
SELECT '01'
UNION
SELECT '02'
UNION
SELECT '03'
UNION
SELECT '04'
UNION
SELECT '05'
UNION
SELECT '06'
UNION
SELECT '07'
UNION
SELECT '08'
UNION
SELECT '09'
UNION
SELECT '10'
UNION
SELECT '11'
UNION
SELECT '12'
)
SELECT cte.cMonth, SUM(o.sum_acount_cur) OVER(ORDER BY cte.cMonth) sum_acount_cur 
FROM cte
LEFT JOIN 
(SELECT EXTRACT( MONTH FROM oper_data) AS cMonth, SUM(sum_acount_cur) AS sum_acount_cur FROM operation GROUP BY EXTRACT( MONTH FROM oper_data)) o ON o.cMonth = cte.cMonth
;
0
0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22
14.07.2022, 14:08  [ТС]
Пробую, спасибо за вариант!

Добавлено через 24 минуты
Не. нерабочий пример. И допилить не получается. просто при джоинить календарь, и я могу. Вопрос в том. что бы суммы переносились и что бы слинковать полную дату с месяцем в календаре.
Пример календаря:
SQL
1
2
3
4
SELECT 
  (SELECT to_char(to_timestamp(to_char(EXTRACT ('month' FROM  date_trunc('month',(SELECT DISTINCT date_trunc('day',oD) AS "oper_data"))), '999'), 'MM'), 'Mon'))AS "month" 
FROM generate_series('01.04.2022','30.08.2022','1 month'::INTERVAL) AS oD
 ORDER BY MONTH
0
0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22
17.07.2022, 11:14  [ТС]
SQL Error:ОШИБКА: таблица "operation" отсутствует в предложении FROM
LINE 30: ...BY EXTRACT( MONTH FROM operation.oper_data)) o ON operation....

Прошу помощи. Все за ранее благодарен.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.07.2022, 11:14
Помогаю со студенческими работами здесь

Сложить между собой поля записей в таблице нарастающим итогом
Друзья, такая задача: есть таблица записей - индекс и числовое поле. Необходимо запросом вывести оба поля и добавить еще одно, в которое...

Суммеслимн и суммеслимн (с нарастающим итогом) в запросе MS Access
Всем здравствуйте. Очень нужна ваша помощь с реализацией 2-х формул MS Excel в MS Access. Каким образом это можно реализовать в MS...

Посчитать последовательность нарастающим итогом
Добрый вечер! У меня возникла проблема с vba. Существует какая-то последовательность чисел (например 1,2,3,4,5) Необходимо написать их...

Запрос с нарастающим итогом в access
Доброго времени суток всем. Помогите, пожалуйста, решить такую проблему: Есть таблица (наименование сырья, дата, расход сырья) ...

Свод нарастающим итогом из нескольких листов
Здравствуйте, уважаемые программисты!!! Очень нужна Ваша помощь!!!! Есть файл Excel, каждый лист соответствует месяцу. На листе отражены...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
27
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru