19.06.2020 Карцев Кирилл 24835
Использование нескольких группировок в 1С 8.3

Содержание:

1.    Как использовать несколько группировок в одном запросе

2.    Примеры использования такого способа группировок в 1С 8.3

3.    Плюсы и минусы использования несколько группировок в одном запросе 


Начиная с платформы 8.3.16. 1030 появилась возможность использовать несколько группировок в одном запросе. Это – поддержка конструкции GROUPING SETS (группирующие наборы) из языка запросов SQL. 


1.    Как использовать несколько группировок в одном запросе


Визуально настройка выглядит следующим образом.




Появилась галка «Использовать несколько группировок в 1С 8.3». Ее включение позволяет добавить в запрос две и более группировок в одной выборке данных.


Это удобно, когда из одних и тех же данных нужно собрать несколько разных сгруппированных таблиц.


При использовании этой конструкции следует понимать, что набор суммируемых полей одинаковый для всех группировок. Различаться могут только поля группировки 1С. Если требуются разные поля суммирования, объединить их в один запрос с помощью GROUPING SETS не получится. То есть все-таки придется сделать несколько отдельных подзапросов.


Поля группировки 1С, не попадающие в текущую группу, принимают в значение NULL. 


2.    Примеры использования такого способа группировок в 1С 8.3 


Рассмотрим несколько примеров использования новой возможности 1С.


Первый пример – подсчет количества номенклатурных позиций в базе в разрезе видов и типов номенклатуры 1С.




В результате получаем таблицу, в которой отдельно посчитано количество позиций по видам, количество позиций и по типам номенклатуры 1С. Все данные получены одним запросом в сводную таблицу и готовы для дальнейшей обработки.




В этом же запросе можно добавить еще одну группировку по виду и типу номенклатуры в 1С и получить все три набора данных одновременно в одной выборке.


Второй пример. Подсчет общих итогов по складу с разверткой по номенклатуре.

Имеем типовой регистр современной базы 1С – ТоварыНаСкладах.




Порядок: Склад, Номенклатура.



 

С помощью такой конструкции можно посчитать в 1С количество товара сначала по Складу, потом по номенклатуре и текущему складу. И нет необходимости делать выборку с группировкой, как приходилось делать ранее.


Записи полученной таблицу будут идти в следующем порядке:

      Склад 1 и Null – итог по текущему складу;

      Склад 1 и Номенклатура 1 – итог по складу и номенклатуре 1;

      Склад 1 и Номенклатура 2 – итог по складу и номенклатуре 2.


Получаем тот же вариант расчетов с итогами, что в выборке с группировкой, только быстрее и проще реализуемый код 1С:Предприятие.


Третий пример. Подсчет общего итога.

Бывают ситуации, что в коде 1С:Предприятие нужно знать итог по полученной выборке.

В таких случаях заводили отдельную переменную и в нее выгружали Итог = ТаблицаВыборки.Итог(«ПолеСуммы»);


Теперь это можно сделать на уровне запроса вот таким образом:




Добавляем новую группировку без полей группировки.

Сортировка по полям Склад и номенклатура.


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


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



 

3.    Плюсы и минусы использования несколько группировок в одном запросе 


Плюсы

Какие же есть плюсы от использования новой конструкции в запросах?


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


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


В-третьих, в некоторых случаях такая конструкция убирает необходимость в разработке дополнительных алгоритмов обработки данных, которые приходилось дополнять ранее (например, расчет общих итогов или итоги по разным наборам группировок).


Ограничения

У конструкции GROUPING SETS есть несколько ограничений:

1. Поддержка СУБД по версиям:

·         Oracle – начиная с версии 10.2 (кроме строковых полей);

·         PostgreSQL – начиная с версии 10.3;

·         IBM DB2 – начиная с версии 11;

·         MSSQL – начиная с версии 2008.


2. Набор суммируемых полей одинаковый для всех наборов группировок.

То есть одно поле может быть либо в поле одной из группировок, либо в «суммируемом поле».


Специалист компании ООО «Кодерлайн»

Карцев Кирилл

Наши проекты

МГК "Световые Технологии"
МГК "Световые Технологии"

Отрасль:

Внедренное типовое решение:
1С:Предприятие 8. ERP Управление предприятием 2

Специалисты "Кодерлайн" произвели доработки в системе 1С:ЕРП 2.4 с учетом треб...

ООО ХДМ Рус
ООО ХДМ Рус

Отрасль:
Торговля

Внедренное типовое решение:
1С:Бухгалтерия ПРОФ

Бухгалтерский учет Банк и касса Расчеты с контрагентами Торговые операции ...

ПЭК
ПЭК

Отрасль:
Грузоперевозки

Внедренное типовое решение:
1С:Зарплата и управление персоналом

- Перевод зарплатных баз с версии ЗУП 2.5 на версию ЗУП 3.1.
- Сопровождение в п...

ООО "Смена"
ООО "Смена"

Отрасль:
Торговля, склад, логистика, транспорт

Внедренное типовое решение:
1С:Комплексная автоматизация

Банк и касса
Расчеты с контрагентами
Торговые операции
Взаиморасчеты с...

АО "Нижегородский водоканал"
АО "Нижегородский водоканал"

Отрасль:
Профессиональные услуги

Внедренное типовое решение:
1С:Зарплата и управление персоналом 8. КОРП

-Кадровый учет
-Расчет зарплаты
-Регламентированная отчетность
-Подбор ...

Автоматизации учета затрат и расчета себестоимости с использованием конфигурации «Koderline: Управление проектами строительства скважин»
ООО «Буровая сервисная компания «ГРАНД»

Отрасль:
Нефтесервис

Внедренное типовое решение:
«Koderline: Управление проектами строительства скважин»

Учет и планирование:
- собственную разработку компании «Кодерлайн» – конф...

ООО «Лаборатория успеха»
ООО «Лаборатория успеха»

Отрасль:
Общественное и плановое питание, гостиничный бизнес, туризм

Внедренное типовое решение:
1С:Управление холдингом 8

Бухгалтерский учет;
Расчет зарплаты и кадровый учет;...

Автоматизация кадрового учета на базе «1С:ERP Управление предприятием 2.0»
Автопредприятие ПАО «Газпром»

Отрасль:
Транспорт

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

- Настройка подсистемы кадрового учета;
- Перенос персональных данных;
- З...

ОАО «Фаберлик»
ОАО «Фаберлик»

Отрасль:

Внедренное типовое решение:
1С:ERP. Управление производственным предприятием 2

- Регламентированный учет;
- Кадровый учет;...

Автоматизация торгового учета на базе "1С:Управление торговлей"
ООО «ТЕЛЕВЕС РУСС»

Отрасль:
Торговля

Внедренное типовое решение:
1С:Управление торговлей

- Управление складскими запасами;
- Оформление заказов покупателей;
- Пла...

ООО «ЛИГА-ТРАНС»
ООО «ЛИГА-ТРАНС»

Отрасль:
Профессиональные услуги, бытовое обслуживание

Внедренное типовое решение:
«1С:ERP Управление предприятием 2.1».

- Сделано ТЗ по автоматизации учета МСФО: - Разработана карта бюджета доходо...

Автоматизации бизнес-процессов учета и планирования на базе «1С:ERP Управление предприятием 2.0»
ООО «Буровая сервисная компания «ГРАНД»

Отрасль:
Нефтесервис

Внедренное типовое решение:
1С:ERP Управление предприятием 2.0

- Создание полноценной управленческой системы взамен существующих
- Внедр...

Наши соц. сети

Telegram-канал «Koderline 1С» Группа в Вконтакте «Кодерлайн КОРП» Rutube

Остались вопросы - обратитесь к нам!

Впишите свои Имя и Телефон, чтобы мы ответили на все интересующие Вас вопросы.
ФИО*
E-mail*
Телефон*
Сообщение