Разбиение запросом записей периодического регистра сведений по интервалам

04.01.21

Разработка - Запросы

Доброго времени суток, коллеги. У меня возникла задача - разбить запросом записи периодического регистра сведений по интервалам. Возможно, кому-то будет интересно решение подобной задачи. Покажу решение на примере регистра "История изменения уровней", в моем случае в нем можно для каждого элемента из справочника "Должности" задать уровень на любой период. Для примера использовал каркасную конфигурацию.   

 Доброго времени суток, коллеги. У меня возникла задача - разбить запросом записи периодического регистра сведений по интервалам. Возможно кому то будет интересно решение подобной задачи.
 Покажу решение на примере регистра "История изменения уровней", в моем случае в нем можно для каждого элемента из справочника "Должности" задать уровень на любой период. Для примера использовал каркасную конфигурацию.    

 
 Запрос к регистру "История изменения уровней"
ВЫБРАТЬ
	ИсторияИзмененияУровней.Должность КАК Должность,
	ИсторияИзмененияУровней.Уровень КАК Уровень,
	ИсторияИзмененияУровней.Период КАК Период
ПОМЕСТИТЬ ВТУровни
ИЗ
	РегистрСведений.ИсторияИзмененияУровней КАК ИсторияИзмененияУровней
ГДЕ
	ИсторияИзмененияУровней.Период <= &КонецПериода
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ВТУровни.Должность КАК Должность,
	МАКСИМУМ(ВТУровни.Период) КАК Период
ПОМЕСТИТЬ ВтМаксимальныеПериод
ИЗ
	ВТУровни КАК ВТУровни

СГРУППИРОВАТЬ ПО
	ВТУровни.Должность
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ВТУровни.Должность КАК Должность,
	ВТУровни1.Период КАК НачалоПериода,
	МИНИМУМ(ДОБАВИТЬКДАТЕ(ВТУровни.Период, СЕКУНДА, -1)) КАК КонецПериода
ПОМЕСТИТЬ ВТПЕРИОДЫ
ИЗ
	ВТУровни КАК ВТУровни
		ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТУровни КАК ВТУровни1
		ПО ВТУровни.Должность = ВТУровни1.Должность
			И ВТУровни.Период > ВТУровни1.Период

СГРУППИРОВАТЬ ПО
	ВТУровни.Должность,
	ВТУровни1.Период

ОБЪЕДИНИТЬ ВСЕ

ВЫБРАТЬ
	ВтМаксимальныеПериод.Должность,
	ВтМаксимальныеПериод.Период,
	ДАТАВРЕМЯ(3999, 12, 31, 23, 59, 59)
ИЗ
	ВтМаксимальныеПериод КАК ВтМаксимальныеПериод
		ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТУровни КАК ВТУровни1
		ПО ВтМаксимальныеПериод.Должность = ВТУровни1.Должность
			И ВтМаксимальныеПериод.Период = ВТУровни1.Период
;

////////////////////////////////////////////////////////////////////////////////
ВЫБРАТЬ
	ВТПЕРИОДЫ.Должность КАК Должность,
	ВТПЕРИОДЫ.НачалоПериода КАК НачалоПериода,
	КОНЕЦПЕРИОДА(ВТПЕРИОДЫ.КонецПериода, ДЕНЬ) КАК КонецПериода,
	ВТУровни.Уровень КАК Уровень
ИЗ
	ВТПЕРИОДЫ КАК ВТПЕРИОДЫ
		ВНУТРЕННЕЕ СОЕДИНЕНИЕ ВТУровни КАК ВТУровни
		ПО ВТПЕРИОДЫ.Должность = ВТУровни.Должность
			И ВТПЕРИОДЫ.НачалоПериода = ВТУровни.Период

 

   Сделал небольшой пример. Вот какие записи есть в регистре.

   

Вот результат выполнения запроса. 




Тестировал на "Каркасная конфигурация для сдачи экзамена "1С:Специалист" по платформе "1С:Предприятие 8" (1.0.0.3)".

Запрос

См. также

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 руб.

02.09.2020    125350    683    389    

734

Пропорциональное распределение в запросе с использованием АвтоНомерЗаписи()

Запросы Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Часто поступают задачи по произвольному распределению общих сумм. После распределения иногда пропадают копейки. Суть решения добавить АвтоНомерЗаписи() в ВТ распределения, и далее используя функции МАКСИМУМ или МИНИМУМ можем положить разницу копеек в первую или последнюю строку знаменателя распределения.

11.04.2024    2318    andrey_sag    10    

29

Для чего используют конструкцию запроса "ГДЕ ЛОЖЬ" в СКД на примере конфигурации 1С:ERP

Запросы СКД Платформа 1С v8.3 Запросы Система компоновки данных 1С:ERP Управление предприятием 2 Бесплатно (free)

В типовых конфигурациях разработчики компании 1С иногда используют в отчетах, построенных на СКД, такую конструкцию, как "ГДЕ ЛОЖЬ". Такая конструкция говорит о том, что данные в запросе не будут получены совсем. Для чего же нужен тогда запрос?

13.02.2024    6056    KawaNoNeko    23    

25

Набор-объект для СКД по тексту или запросу

Запросы СКД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Есть список полей в виде текста, или запрос - закидываем в набор СКД.

1 стартмани

31.01.2024    2163    2    Yashazz    0    

31

Запрос 1С copilot

Инструментарий разработчика Запросы Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Абонемент ($m)

Пишем на человеческом языке, что нам надо, и получаем текст запроса на языке 1С. Используются большие языковые модели (LLM GPT) от OpenAI или Яндекс на выбор.

5 стартмани

15.01.2024    6692    31    mkalimulin    27    

52

PrintWizard: поддержка представлений ЗУП в конструкторе

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

Одной из интересных задач, стоящих в процессе разработки, была поддержка механизма представлений в ЗУП. Но не просто возможность исполнения запросов с ними. Основная проблема была в том, чтобы с ними было удобно работать, а именно: создавать, модифицировать и отлаживать. Кратко о том, что в итоге получилось...

14.12.2023    1905    vandalsvq    7    

29

Объектная модель запроса "Схема запроса" 2

Запросы Платформа 1С v8.3 Запросы Конфигурации 1cv8 Бесплатно (free)

Далеко уже не новый тип данных "Схема запроса". Статья о том, как использовать его "попроще". Примеры создания текста запроса с нуля и изменение имеющегося запроса.

06.12.2023    5655    user1923546    26    

46

Начните уже использовать хранилище запросов

HighLoad оптимизация Запросы

Очень немногие из тех, кто занимается поддержкой MS SQL, работают с хранилищем запросов. А ведь хранилище запросов – это очень удобный, мощный и, главное, бесплатный инструмент, позволяющий быстро найти и локализовать проблему производительности и потребления ресурсов запросами. В статье расскажем о том, как использовать хранилище запросов в MS SQL и какие плюсы и минусы у него есть.

11.10.2023    16649    skovpin_sa    14    

101
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. kamisov 153 29.12.20 18:53 Сейчас в теме
Вот до чего людей доводит отсутствие курсоров!
2. PersianovMS 03.01.21 18:22 Сейчас в теме
Коллега, позволю себе несколько замечаний:
1. ДОБАВИТЬКДАТЕ(ИсторияИзмененияУровней.Период, СЕКУНДА, -1) КАК КонецПрошлогоПериода - это лишнее;
2.А вот добавление поля Уровень в ВТПериоды лишним бы не было, последний запрос не потребуется вовсе;
3.Какова периодичность регистра? Если День и более - зачем НачалоДня? Если меньше - применение НачалоДня и КонецДня может привести к дублям в результате.
Остальное - да, один из годных методов получения результата...
3. Andrei_Ivanov 163 04.01.21 19:30 Сейчас в теме
(2) Добрый день. Спасибо за комментарий.
1. Точно, я поправил этот момент. Зачем то оставил поле, которое не использую в дальнейшем.
2. Ввиду того, что поля в первом запросе объедения группируются по должностям и периодам, если я выношу в него уровень, я получаю некорректный результат. Приложил к сообщению файл с результатом запроса.
3. Периодичность - день. Правда, лишнее действие с началом периода. Также поправил.
Прикрепленные файлы:
Оставьте свое сообщение