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

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

0
7797
19.06.2020 Карцев Кирилл

Содержание:

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. Набор суммируемых полей одинаковый для всех наборов группировок.

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


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

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

Задать вопрос автору статьи
Тема вопроса*
Ваше имя*
E-mail или телефон*
Ваш вопрос*
 

Добавить комментарий
Текст сообщения*
Защита от автоматических сообщений
 
Теги
# абота Риелторского Агентства # Управление торговлей 11 #Работа Риелторского Агентства # 1C # CRM-система # Cинтаксис-помощник # Cинхронные методы работы # PDF документами # PowerShell # XML-файл # Бизнес-процесс # Глубина анализа # Графические объекты # Динамический список # Документ заполнен # Документ Отбор (размещение) товаров # Документ Отгрузка товаров ИС МП # Документ Приобретение товаров и услуг # Документ УПД # Доступ на ТСД # ДтКт # ЕАЭС # Закладка Администрирование # Зарплата и кадры # Имя таблицы # ИТС # Кабель NYM(Севкабель) 3x5.5 # Книга учета доходов и расходов # Курс валюты # Лицо с правом подписи # Лицо, имеющее право подписи документов # Маркировка цифровыми кодами # Минимальные цены продажи в 1С # Настройка НСИ и разделов # Настройка ценообразования # НДФЛ # Нематериальные активы # Обмен электронными документами # Оплата через банк # Основное ответственное лицо организации # Перемещение ТС и оборудования # Проведение инструктажа # Продажи или Закупки # Прочие доходы # Пункт Подключить обработки # Пункт Сервис # ПФР и ФФОМС # Работа ТС # Расчет налога УСН # Расчетные счета # Система «Честный знак» # Система GS1 # Списание на расходы # Справка-расчет налога УСН # Страховые взносы # Таблица формы # Таблица формы «Сотрудники» # Товары # Установка цен на товары # Формат Цифровой Маркировки # Функция Дата # Функция ДеньГода # Функция ДеньНедели # Центральный Банк России # Цены номенклатуры 2.5 # Элементы #1.6-НДФЛ #1С Бухгалтерия #1С: CRM #1С: ERP #1С: ERP Управление строительной организацией #1С: ERP. Управление буровой компанией #1С: WMS Управление складом #1С: Аренда и управление недвижимостью #1С: БУХ #1С: Договорчики #1С: Документооборот #1С: ЗУП #1С: Интеграция #1С: КА #1С: Колледж #1С: Конвертация данных #1С: Модули #1С: Платформа #1С: Розница #1С: Сценарное тестирование #1С: ТОИР #1С: УАТ #1С: УКФ #1С: Университет #1С: УНФ #1С: УПП #1С: Управление строительной организацией #1С: УТ #1С: УХ #1С:ERP #1С:БГУ #1С:БП #1С:Риелтор #1С:Управление холдингом #1С.6-НДФЛ #ADO #APACHE #API #canonical #com-объекты #Cправочник БИК #Excel #Excel в 1С #GoogleDrive #Googleаккаунт #HTTP #ITIL #Koderline: Управление медиа-холдингом #Koderline: Управление проектами строительства скважин #LINUX #MS SQL Server #PDF #WEB #WEB-сервисы 1С #Word #WS-ссылки #XDTO-объект #XML #XML-обмен #Администрирование 1С #Адрес URL описания #акты в 1С #Банковские счета #Безопасность сервера #Бесшовная интеграция #БИТ.Финанc #Битрикс24 #Блокировки в 1С #БСП #БУ #Бурение скважин #Бухгалтерская отчётность в МСФО #Бюджетирование #Вид Характеристики #Внедрение #Внедрение ERP #Внешний вид формы #Выбор каталога #Выбранные файлы #Документ Отпуск #Документ1 #Журналы #Загрузка цен в 1С #Задача для 1С #Закладка Торговля #Закрытие месяца #Заменить #Запись регистра сведений #Запросы 1С #Интеграция 1С #Интервал dpi #История пользователя #Кадровые документы #КАК ОТРАЖАЮТСЯ ТОВАРЫ В ПУТИ 1С #Как сделать в 1С #Карточка Объекта недвижимости #Классификаторы и курсы валют #Клиент-серверная схема #Код ЦМТ #Конвертация данных #Контроль документов #Конфигурация 1С #Конфигурация 1С ЗУП 3.1 #Копирование настроек пользователей #Корпоративное сопровождение #Лизинг #Лицензии 1С #Лицензионный договор #Личные документы #Массив Номенклатур #Массовая регистрация отгулов #Меню Отчет #Механизм Анализа Данных в 1С #Моделирование #Модуль Диадок #МРОТ #МСФО #Налоги #Начисления Арендной платы #Новый Массив #Обмен между базами #Обновления #Общие ознакомительные рассылки #Операции в 1С #Оптимизация #Организация #Отпуск #Отчетность #Отчеты в 1С #Оформление перевода работника #Оценка задач #Параметр «Количество» #Партнер #Передача неисключительных прав #Перенос данных #Перенос цен из Excel в 1С #Периодичность ДЕНЬ #Периодичность МЕСЯЦ #Печатная форма документа #Планирование #Поле Ввода Значение Субконто #Полезные обработки #Пользовательский режим #Правила обмена #предопределенные элементы справочников #Прием на работу #Принцип работы 1С #Проводки 1С #Программа 1С #Программирование в 1С #Программные права #Продажа ТМЦ #Продажи #Продление #Производство #Просмотр #Путь к файлу #Работа с объектами в 1С #Расторжение #Расчет зарплаты #Расчетные документы #Расширение конфигурации #Регламентированная отчетность #Режим РИБ #Результаты поиска #РСБУ #С # #Сдельный заработок #СЗВ-СТАЖ #СКД #Соединение COM в 1С платформе #Соединение СОМ в 1С платформе #Сравнение конфигураций #Счет-фактура #Текущая Строка #Территориальная привязка #Территориальные рамки #Тестирование 1С #Техническое задание #Типы данных ссылки #Торговое оборудование #Транспортная логистика #Управление проектами #Установка цен номенклатуры #Финансовый учет #Формат MicrosoftExcel #Функционал МРМ #Х-точка #Характеристики Товаров #Хранилище настроек #Хранить историю изменений #Ценообразование #Чтение #Экзамен 1С #электронные подписи #Яндекс-диск или Google-диск #Яндекс.Касса 1С под Linux 1С:УНФ Email или телефон Работа с объектами в 1С Функциональные опции в 1С
Услуги программиста 1С
Получите специалиста  
для решения всех задач
в области 1С
Программы 1С
Цены и подробное описание программ 1С:Предприятие 8.