Уровни иерархии предков элементов справочника запросом

25.07.13

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

Предлагаю вниманию случай использования методики, описанной автором    ildarovich [http://infostart.ru/profile/28527/] в статье [http://infostart.ru/public/160707/]
Одним пакетным запросом для каждого элемента справочника выводятся уровни всех его предков.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Уровни0.png
.png 8,35Kb
1
1 Скачать (1 SM) Купить за 1 850 руб.

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

Функция УровниПрародителей(ИмяСправочника, МаксимальнаяДлинаПути) Экспорт

    Пролог = "ВЫБРАТЬ Родитель НачалоДуги, Ссылка КонецДуги ПОМЕСТИТЬ ЗамыканияДлины1 ИЗ Справочник.Номенклатура
            | ГДЕ Родитель <> Значение(Справочник.Номенклатура.ПустаяСсылка)
            | ОБЪЕДИНИТЬ ВЫБРАТЬ Ссылка, Ссылка ИЗ Справочник.Номенклатура;";

    Рефрен = "ВЫБРАТЬ РАЗЛИЧНЫЕ ПерваяДуга.НачалоДуги, ВтораяДуга.КонецДуги ПОМЕСТИТЬ ЗамыканияДлины#2 ИЗ ЗамыканияДлины#1 КАК ПерваяДуга
            | СОЕДИНЕНИЕ ЗамыканияДлины#1 КАК ВтораяДуга ПО ПерваяДуга.КонецДуги = ВтораяДуга.НачалоДуги;
            | УНИЧТОЖИТЬ ЗамыканияДлины#1;";

	//Все предки
    Эпилог1 = "ВЫБРАТЬ НачалоДуги Предок, КонецДуги Потомок Поместить Предки ИЗ ЗамыканияДлины#2
            | ГДЕ НачалоДуги <> КонецДуги ;";
			
	//Уровни групп-предков		
    Эпилог2 = "ВЫБРАТЬ КОЛИЧЕСТВО(НачалоДуги) - 1 Предок, КонецДуги Потомок Поместить Уровни ИЗ ЗамыканияДлины#2 СГРУППИРОВАТЬ ПО КонецДуги;";

    Итог = "Выбрать Предки.Предок Как Предок, Уровни.Предок Как Уровень,  Предки.Потомок Как Потомок  Из Предки Как Предки 
            | ЛЕВОЕ СОЕДИНЕНИЕ   Уровни Как Уровни По Предки.Предок = Уровни.Потомок 
            | ГДЕ Предки.Потомок.ЭтоГруппа = Ложь 
			| Упорядочить По Предки.Потомок.Наименование, Уровни.Предок 
            | ";
	
    Запрос = Новый Запрос(СтрЗаменить(Пролог, "Номенклатура", ИмяСправочника));

    МаксимальнаяДлинаЗамыканий = 1;

    Пока МаксимальнаяДлинаЗамыканий < МаксимальнаяДлинаПути Цикл

        Запрос.Текст = Запрос.Текст + СтрЗаменить(СтрЗаменить(Рефрен, "#1", Формат(МаксимальнаяДлинаЗамыканий, "ЧГ=0")), "#2", Формат(2 * МаксимальнаяДлинаЗамыканий, "ЧГ=0"));

        МаксимальнаяДлинаЗамыканий = 2 * МаксимальнаяДлинаЗамыканий

    КонецЦикла;

    Запрос.Текст = Запрос.Текст + СтрЗаменить(Эпилог1, "#2", Формат(МаксимальнаяДлинаЗамыканий, "ЧГ=0"));
	
	Запрос.Текст = Запрос.Текст + СтрЗаменить(Эпилог2, "#2", Формат(МаксимальнаяДлинаЗамыканий, "ЧГ=0"));
	
	Запрос.Текст = Запрос.Текст + Итог;

    Возврат Запрос.Выполнить().Выгрузить()

КонецФункции



Спасибо  ildarovich за великолепную реализацию результатов теории графов  с использованием языка запросов 1С! (См. [//infostart.ru/public/160707/])



См. также

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

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

15500 руб.

02.09.2020    184698    1029    403    

968

Обновление 1С Запросы Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

Данный инструмент помогает анализировать доработанную конфигурацию после обновления на новый релиз и находить «битые» тексты запросов, в которых участвуют несуществующие в новом релизе метаданные.

2 стартмани

06.02.2025    2199    17    XilDen    26    

36

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

В статье приведена удобная возможность отладки исполняемого запроса динамического списка.

03.12.2024    5731    artemusII    11    

23

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    13138    sergey279    18    

66

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    8218    XilDen    36    

90

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

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    3191    PROSTO-1C    0    

23

Запросы Программист Запросы Бесплатно (free)

Отлаживая взаимодействие с базой данных, мы регулярно сталкиваемся с зависающими или подозрительно долго выполняющимися обращениями, негативно влияющими на производительность. О том, как в PostgreSQL выявить подозрительные запросы, основываясь на доступной о них информации, расскажем в статье.

16.08.2024    10799    user1840182    5    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. petrov_al 10 26.07.13 16:01 Сейчас в теме
Это выложенная перепечатка или тут есть что то новое?
2. zaxarovsky 111 26.07.13 16:25 Сейчас в теме
тут написана новая функция на основе компиляции двух примеров из статей ildarovich.
мне нужно было получить таблицу именно такой структуры как здесь показано на картинке.
Оставьте свое сообщение