gifts2017

Заметка об использовании В ИЕРАРХИИ()

Опубликовал LittleFairy (LittleFairy) в раздел Программирование - Практика программирования

Очень специфическая задача, в которой мне захотелось использовать В ИЕРАРХИИ()


Происходит некий процесс с участием элемента справочника "номенклатура"
Процесс зависит от того, входят ли группы, содержащие этот элемент в определенный регистр сведений.
Т.о. нужно определить, содержат ли в себе группы, указанные в регистре обрабатываемый элемент.

С ходу я написал примерно следующее:

Запрос = Новый Запрос;
Запрос.Текст = "
|ВЫБРАТЬ
| Ссылка
|ИЗ Справочник.Номенклатура КАК Номенклатура
|ГДЕ Ссылка = &Ссылка 
| И Ссылка В ИЕРАРХИИ(ВЫБРАТЬ
|                        Группа
|                     ИЗ РегистрСведений.Группы КАК Группы)
|;"

Далее происходит ветвление алгоритма в зависимости от того, пуст результат запроса или нет.
Естественно, при большом справочнике "Номенклатура" это будет работать медленно.

Гораздо эффективнее сделать так:

СписокРодителей = ПолучитьСписокРодителей(Ссылка);//Функция не является стандартной
Запрос = Новый Запрос;
Запрос.Текст = "
|ВЫБРАТЬ
| Группа
|ИЗ РегистрСведений.Группы КАК Группы
|ГДЕ Группа В (&СписокРодителей) 
|;"

Мораль: решение, кажущееся мне очевидным не всегда лучшее )

См. также

Подписаться Добавить вознаграждение

Комментарии

1. Призрак (davdykin) 16.05.14 05:17
Как мне кажется именно для этих целей есть Временные таблицы, и пакетные запросы.
arccos6pi; Артано; Re:аниматор; +3 Ответить
2. Василий Пупкин (AgregatAvia) 16.05.14 07:22
и что же делает загадочная функция "ПолучитьСписокРодителей(Ссылка)"?
TrinitronOTV; BigB; kasper076; +3 Ответить 2
3. ффф ыыы (zqzq) 16.05.14 08:41
"В ИЕРАРХИИ" вообще медленное выражение, его даже для использования в РЛС запретили от греха подальше.

Надо бы посмотреть, в какой запрос SQL 1с-ка его разворачивает.

Вывод: "В ИЕРАРХИИ" кроме как в отчетах лучше нигде больше не использовать.
4. Сергей Ожерельев (Поручик) 16.05.14 12:16
(2) Я думаю, она получает список групп или родителей для переданной ссылки на что-то.
5. Дмитрий Бухалов (Re:аниматор) 16.05.14 16:23
Подскажите пжл как минус поставить за эту "полезную" статью?
artbear; itmind; cleaner_it; Puk2; arccos6pi; Makushimo; Артано; +7 Ответить
6. анд гру (agrustny) 16.05.14 16:51
Зачем так позориться?
arccos6pi; +1 Ответить
7. Андрей Акулов (DrAku1a) 21.05.14 02:52
(2)
Перем СЗ, Р;
СЗ = новый СписокЗначений();
Р = Ссылка.Родитель;
Пока не Р.Пустая() цикл
 СЗ.Добавить(Р);
 Р = Р.Родитель; 
КонецЦикла;
Возврат СЗ;
...Показать Скрыть
8. Виталий Криволапов (Vit aka proger) 21.05.14 08:59
Т.е. в первом случае ты загружаешь в память ВСЮ номенклатуру и удивляешься, что этот запрос работает медленнее второго???
Я бы сделал как-то так:

"
|ВЫБРАТЬ
|&Ссылка КАК Номенклатура
|ПОМЕСТИТЬ ВТ;
|
|ВЫБРАТЬ
| ВТ.Номенклатура
|ИЗ ВТ КАК ВТ
|ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.Группы КАК Группы
|ПО ВЫБОР
|когда ВТ.Номенклатура.Родитель = ЗНАЧЕНИЕ(Справочник.Номенклатура.ПустаяСсылка)тогда
|ЛОЖЬ
|когда Группы.Группа = ВТ.Номенклатура.Родитель тогда
|ИСТИНА
|когда ВТ.Номенклатура.Родитель.Родитель = ЗНАЧЕНИЕ(Справочник.Номенклатура.ПустаяСсылка) тогда
|ЛОЖЬ
|когда Группы.Группа = ВТ.Номенклатура.Родитель.Родитель тогда
|ИСТИНА
.........
|ИНАЧЕ
|ЛОЖЬ
|КОНЕЦ
|;"
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа