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

16.05.14

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

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


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

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

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

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

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

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

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

В ИЕРАРХИИ

См. также

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

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

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

10000 руб.

02.09.2020    124643    681    389    

732

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

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

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

11.04.2024    2101    andrey_sag    10    

27

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

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

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

13.02.2024    5973    KawaNoNeko    23    

25

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

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

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

1 стартмани

31.01.2024    2139    2    Yashazz    0    

30

Запрос 1С copilot

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

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

5 стартмани

15.01.2024    6603    31    mkalimulin    27    

51

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

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

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

14.12.2023    1874    vandalsvq    7    

29

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

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

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

06.12.2023    5604    user1923546    26    

46

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

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

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

11.10.2023    16557    skovpin_sa    14    

101
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. davdykin 25 16.05.14 05:17 Сейчас в теме
Как мне кажется именно для этих целей есть Временные таблицы, и пакетные запросы.
arccos6pi; Артано; Re:аниматор; +3
2. AgregatAvia 16.05.14 07:22 Сейчас в теме
и что же делает загадочная функция "ПолучитьСписокРодителей(Ссылка)"?
TrinitronOTV; BigB; kasper076; +3
4. Поручик 4674 16.05.14 12:16 Сейчас в теме
(2) Я думаю, она получает список групп или родителей для переданной ссылки на что-то.
+
7. DrAku1a 1715 21.05.14 02:52 Сейчас в теме
(2)
Перем СЗ, Р;
СЗ = новый СписокЗначений();
Р = Ссылка.Родитель;
Пока не Р.Пустая() цикл
 СЗ.Добавить(Р);
 Р = Р.Родитель; 
КонецЦикла;
Возврат СЗ;
Показать
+
3. zqzq 23 16.05.14 08:41 Сейчас в теме
"В ИЕРАРХИИ" вообще медленное выражение, его даже для использования в РЛС запретили от греха подальше.

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

Вывод: "В ИЕРАРХИИ" кроме как в отчетах лучше нигде больше не использовать.
+
5. Re:аниматор 338 16.05.14 16:23 Сейчас в теме
Подскажите пжл как минус поставить за эту "полезную" статью?
artbear; itmind; cleaner_it; Puk2; arccos6pi; Makushimo; Артано; +7
6. agrustny 19 16.05.14 16:51 Сейчас в теме
Зачем так позориться?
arccos6pi; +1
8. Vit aka proger 105 21.05.14 08:59 Сейчас в теме
Т.е. в первом случае ты загружаешь в память ВСЮ номенклатуру и удивляешься, что этот запрос работает медленнее второго???
Я бы сделал как-то так:

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