Объединение и исключение периодов в запросах

05.05.25

Разработка - Инструментарий разработчика

Слияние и/или удаление периодов с помощью запросов 1С.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Объединение и исключение периодов в запросах
.epf 10,18Kb ver:1.0
28 2 150 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

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

 
 Случаи объединения
 
 Случаи исключения

 

Суть метода такова:

- готовим числовой ряд;

- разбиваем периоды на дни;

- {если удаляем периоды} разбиваем исключаемые периоды на дни;

- {если удаляем периоды} оставляем только дни из исходных периодов;

- находим промежутки между оставшимися соседними днями;

- получаем минимальный и максимальный день из исходных дней {или из оставшихся дней}, т.е. крайние границы диапазонов;

- даты начал периодов соберем из минимальной границы и конечных дат промежутков;

- даты концов периодов соберем из максимальной границы и начальных дат промежутков;

- сгруппируем попарно даты начал и даты концов;

- profit!

 

Кому лень кодить - берите и юзайте полностью открытый код из обработки. (Проверено на платформе 8.3.20, но будет работать и на 8.2+)

 

Небольшие тонкости: алгоритм из коробки будет работать для заполненных и правильных периодов, т.к. числовой ряд рассчитан на диапазон в ~180 лет, т.е. пустую дату надо заменять, например на 01.01.1900 (вряд ли кто-то ведёт бизнес с более ранней даты), и должно выполняться условие (ДатНач<=ДатКон). Конечно, можно расширить числовой ряд до 2^20 (или еще больше), чтобы охватывать '00010101', но тогда запрос будет выполняться несколько секунд.

 

Пример проверки объединения периодов:

 

 

Пример проверки исключения периодов:

 

 

P.S. Может, это и боян, но с наскока не удалось найти подобных реализаций на данном портале именно с помощью запросов...

Проверено на следующих конфигурациях и релизах:

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.11.155

Вступайте в нашу телеграмм-группу Инфостарт

период периоды запрос запросы объединение слияние исключение удаление диапазон диапазоны разбиение интервалы

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    210898    1157    413    

1043

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    39627    217    113    

204

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

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

16000 руб.

10.11.2023    18547    78    39    

92

Инструментарий разработчика Программист 1С v8.3 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9500 руб.

17.05.2024    37166    136    55    

176

Пакетная печать Печатные формы Инструментарий разработчика Программист 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    26093    65    30    

96

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше.<br/> Далее в публикации:<br/> MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    2976    4    7    

12

Инструментарий разработчика 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    3586    7    0    

12
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. dabu-dabu 319 16.02.22 15:46 Сейчас в теме
У вас способ "в лоб". Боюсь, что работает крайне не быстро
Советую почитать статьи ув. ildarovich
Например в минимализмах было: Минимализмы 3
2. SerVer1C 984 16.02.22 16:21 Сейчас в теме
(1) Менее секунды )
Статьи маэстро читал. Он и сам говорит, что множество периодов, идущих в подряд, запросом не объединить без разбивки. Можно было бы рекурсивными запросами, но 1С такое не поддерживает (надеюсь, пока что...).
Дмитрий74Чел; +1 Ответить
Для отправки сообщения требуется регистрация/авторизация