0 / 0 / 0
Регистрация: 27.04.2022
Сообщений: 22

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

01.07.2022, 11:47. Показов 2231. Ответов 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
671 / 294 / 120
Регистрация: 12.04.2022
Сообщений: 1,003
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
671 / 294 / 120
Регистрация: 12.04.2022
Сообщений: 1,003
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
671 / 294 / 120
Регистрация: 12.04.2022
Сообщений: 1,003
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 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru