Интерактивное формирование текста запроса для получения родителей всех уровней справочника

01.08.25

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

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

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
Интерактивное формирование текста запроса для получения родителей всех уровней справочника
.epf 9,69Kb
0 1 850 руб. Купить

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

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

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

 

Вступление

Всех приветствую. Хочу поделиться своей обработкой для 1С, при помощи которой можно интерактивно генерировать текст запроса для получения родителей верхнего уровня иерархического (И не только!) справочника. Эта задача часто возникает, когда нужно определить корневую группу для любого элемента, независимо от глубины иерархии прямо в запросе.

 

Источник вдохновения

За основу бралась статья Транзитивное замыкание запросом. Отдельная благодарность автору за разрешение написания статьи, правда, руки у меня дошли только спустя год 🫠 Надеюсь, время действия разрешения не истекло.

 

В чем особенность

Моей задачей было сделать так, чтобы можно было удобно использовать интерактивно под различные задачи, а также добавить дополнительные возможности: 

  • Поменять имена колонок 
  • Задать ограничение элементов 
  • Поместить результат во временную таблицу
  • Получить родителей по любому реквизиту, отличному от родителя 

 

Использование

Откройте обработку в любой базе (но если в базе нет справочника, для которого вы пишите запрос, то текст не будет отформатирован). Заполните данные на форме, большинство из них заполнятся автоматически, при необходимости можно их поменять: 

  • Имя справочника: Название справочника, для которого определяются верхние родители в иерархии.

  • Максимальная длина пути: Максимальное количество уровней вложенности в иерархии справочника.

  • Имя реквизита иерархии: Реквизит, определяющий иерархию, если она строится не по стандартному полю "Родитель".

  • Получить родителей групп: Включать ли в результат иерархию групп (если Ложь, возвращаются родители только для элементов).

  • Имя временной таблицы: Имя временной таблицы для сохранения результата; если не указано, формируется обычная выборка данных.

  • Имя параметра с элементами: Если задано, родители определяются только для указанных в параметре элементов (пустое значение — параметр объявлен не будет). Пересекается с параметром "Получить родителей групп".

  • Имя колонки элемент: Название колонки с элементами в результирующей выборке.

  • Имя колонки родитель: Название колонки с верхними родителями в результирующей выборке.

 

После заполнения, нажмите кнопку "Заполнить тексты запросов". На форме заполнятся 2 (если справочник в текущей базе не найден) или 4 поля с текстами запросов:

Компактный (для конструктора) - если хотите вставить в конструктор или в консоль запросов

Компактный (для конфигуратора) - если хотите вставить сразу в модуль

А также их форматированные через схему запроса варианты.

 

Открытый код

Любой может что-то добавить или исправить. Если вы хотите использовать основную функцию формирования в своей конфигурации (например, для ее использования через менеджер временных таблиц), то можете скопировать код, который представлен ниже:

&НаКлиентеНаСервереБезКонтекста
// Текст запроса для получения родителей всех уровней иерархии
//
// Параметры:
//  ИмяСправочника			 - Строка - Имя справочника, внутри которого необходимо получить родителей 
//  МаксимальнаяДлинаПути	 - Число  - Максимально возможное количество уровней вложенности в справочнике
//  ИмяРеквизитаИерархии	 - Строка - Имя реквизита, на котором строится иерархия (на случай, если иерархия строится другим, отличным от родителя, реквизитом)
//  ПолучитьРодителейГрупп	 - Булево - Включить в результат запроса иерархию групп (Ложь = Получить родителей только элементов)
//  ИмяВременнойТаблицы		 - Строка - Если указано, то результат будет помещен в указанную временную таблицу, иначе будет сформирован текст с выборкой данных
//  ИмяПараметраСЭлементами	 - Строка - Если указать, то родители будут получы только у элементов из данного параметра ("" = У всех элементов). Обратите внимание, что параметр пересекается с параметром "ПолучитьРодителейГрупп"
//  ИмяКолонкиЭлемент		 - Строка - Имя колонки с элементами в результате запроса
//  ИмяКолонкиРодитель		 - Строка - Имя колонки с родителями в результате запроса
// 
// Возвращаемое значение:
//  Строка - Текст запроса, при помощи которого можно получить родителей всех уровней иерархии.
//
Функция ТекстЗапросаДляПолученияРодителейВсехУровнейИерархии(Знач ИмяСправочника, Знач МаксимальнаяДлинаПути = 8, Знач ИмяРеквизитаИерархии = "Родитель", Знач ПолучитьРодителейГрупп = Ложь,
		Знач ИмяВременнойТаблицы = "", Знач ИмяПараметраСЭлементами = "", Знач ИмяКолонкиЭлемент = "Ссылка", Знач ИмяКолонкиРодитель = "Родитель")
	
	Пролог = "ВЫБРАТЬ #ИмяРеквизитаИерархии НачалоДуги, Ссылка КонецДуги ПОМЕСТИТЬ ЗамыканияДлины1 ИЗ Справочник.#ИмяСправочника
	| ГДЕ #ИмяРеквизитаИерархии <> Значение(Справочник.#ИмяСправочника.ПустаяСсылка)
	| ОБЪЕДИНИТЬ ВЫБРАТЬ Ссылка, Ссылка ИЗ Справочник.#ИмяСправочника
	| #СтрУсловия;";
	
	СтрУсловия = ?(ПустаяСтрока(ИмяПараметраСЭлементами), "", "ГДЕ Ссылка В(&" + ИмяПараметраСЭлементами + ")");
	СтрУсловия = СтрУсловия + ?(ПолучитьРодителейГрупп, "", ?(ПустаяСтрока(СтрУсловия), "ГДЕ", " И") + " ЭтоГруппа = Ложь"); 
	
	Пролог = СтрЗаменить(Пролог, "#СтрУсловия", СтрУсловия);
	
	Рефрен = "ВЫБРАТЬ РАЗЛИЧНЫЕ ПерваяДуга.НачалоДуги, ВтораяДуга.КонецДуги ПОМЕСТИТЬ ЗамыканияДлины#2 ИЗ ЗамыканияДлины#1 КАК ПерваяДуга
	| ВНУТРЕННЕЕ СОЕДИНЕНИЕ ЗамыканияДлины#1 КАК ВтораяДуга ПО ПерваяДуга.КонецДуги = ВтораяДуга.НачалоДуги;
	| УНИЧТОЖИТЬ ЗамыканияДлины#1;";
	
	Эпилог = "ВЫБРАТЬ НачалоДуги КАК #ИмяКолонкиРодитель, КонецДуги КАК #ИмяКолонкиЭлемент" + ?(ПустаяСтрока(ИмяВременнойТаблицы), "", " ПОМЕСТИТЬ " + ИмяВременнойТаблицы) + " ИЗ ЗамыканияДлины#2 ГДЕ НачалоДуги <> КонецДуги";
	
	ТекстЗапроса = Пролог;
	ТекущаяДлинаЗамыканий = 1;
	
	Пока ТекущаяДлинаЗамыканий < МаксимальнаяДлинаПути Цикл
		ТекстЗапроса = ТекстЗапроса + СтрЗаменить(СтрЗаменить(Рефрен, "#1", Формат(ТекущаяДлинаЗамыканий, "ЧГ=0")), "#2", Формат(2 * ТекущаяДлинаЗамыканий, "ЧГ=0"));
		ТекущаяДлинаЗамыканий = 2 * ТекущаяДлинаЗамыканий;
	КонецЦикла;
	
	ТекстЗапроса = ТекстЗапроса + СтрЗаменить(Эпилог, "#2", Формат(ТекущаяДлинаЗамыканий, "ЧГ=0"));
	ТекстЗапроса = ТекстЗапроса + "; УНИЧТОЖИТЬ ЗамыканияДлины" + Формат(ТекущаяДлинаЗамыканий, "ЧГ=0");
	
	ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "#ИмяСправочника",       ИмяСправочника);
	ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "#ИмяРеквизитаИерархии", ИмяРеквизитаИерархии);
	ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "#ИмяКолонкиЭлемент",    ИмяКолонкиЭлемент);
	ТекстЗапроса = СтрЗаменить(ТекстЗапроса, "#ИмяКолонкиРодитель",   ИмяКолонкиРодитель);
	
	Возврат ТекстЗапроса;
	
КонецФункции  

 

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

  • 1С:ERP Управление предприятием 2, релизы 2.5.23.59
  • 1С:Зарплата и кадры бюджетного учреждения, релизы 1.0.121.2
  • Документооборот КОРП, редакция 3.0, релизы 3.0.18.19

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

Обработка запросы запрос иерархия родитель справочник текст

См. также

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

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

15500 руб.

02.09.2020    202364    1116    410    

1021

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

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

8400 руб.

20.08.2024    35562    206    104    

195

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

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

22200 руб.

06.10.2023    23954    62    26    

92

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

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

16000 руб.

10.11.2023    16443    69    39    

88

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

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

9360 руб.

17.05.2024    34643    123    53    

165

SALE! 30%

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

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 12600 руб.

22.11.2024    1707    1    0    

8

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

6000 руб.

07.02.2018    107142    249    100    

313

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

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

3600 руб.

27.12.2024    2860    6    0    

11
Оставьте свое сообщение