Как запросом получить всю иерархию папок в которую входит элемент справочника!? #673209


#0 by yabes
Здравствуйте! Как запросом получить ссылки на группы элементов справочника, в которые входит элемент справочника?
#1 by shuhard
родитель.родитель.родитель.......
#2 by Юрий Юрьевич
рекурсивное формирование текста запроса тоже подойдет
#3 by mikecool
о сколько нам открытий чудных готовит просвещенья дух... напишите уже хранимку, которая будет возвращать список родителей )))
#4 by MiniMuk
Тепо просто список родителей, или ты с ними в запросе еще чтото делать будешь?
#5 by skiller3000
итоги по ссылка иерархия?
#6 by MiniMuk
вот с итогами он потом в запросе ниче и не сделает
#7 by yabes
Буду использовать в запросе!
#8 by 1Сергей
как в Запросе вызывать потом эту хранимку?
#9 by Ёпрст
за нафига ? чем иерархия не катит ?
#10 by Ёпрст
и можно не итоги, а упорядочивание по   Иерархия делать
#11 by пыхтачокк
а зачем вообще запрос...? просто по условию задачи - обязательно запросом?
#12 by PR
Для произвольного количества уровней никак.
#13 by Fragster
тут надо курить СКД - в не2й есть возможность "что-то делать" с иерархией
#14 by PR
Не получится. С точки зрения запроса там все так же как и в не СКД.
#15 by Fragster
там иерархию можно прилепить отдельным набором и делать многое вычисляемыми полями
#16 by PR
ТС говорит про использование этих данных дальше в запросе.
#17 by Fragster
ну да. надо эти данные использовать в вычисляемых полях СКД, а не в запросе.
#18 by Eugeneer
ИТОГИ ПО ИЕРАРХИЯ Номенклатура. Получает всю иерархию.
#19 by PR
Не позорься, Маня :)) Во вложенном запросе нельзя использовать ИТОГИ :))
#20 by fisher
Можно несколько примеров из "многого"?
#21 by Fragster
Синтаксис: Описание: Функция предназначена для вычисления выражения в контексте некоторой группировки. Функция учитывает отбор группировок, но не учитывает иерархические отборы. Функция не может применяться к группировке в групповом отборе этой группировки. Например, в отборе группировки Номенклатура нельзя использовать выражение ВычислитьВыражение(«Сумма(СуммаОборот)”, , «ОбщийИтог») > 1000. Но такое выражение можно использовать в иерархическом отборе. Если конечная запись предшествует начальной, то считается, что записи для расчета детальных данных и расчета агрегатных функций отсутствуют. При расчете интервальных выражений для общего итога (параметр Группировка имеет значение ОбщийИтог) считается, что записи для расчета детальных данных и расчета агрегатных функций отсутствуют. Компоновщик макета при генерации выражения функции ВычислитьВыражение, в случае если выражение упорядочивания содержит поля, которые не могут быть использованы в группировке, заменяет функцию ВычислитьВыражение на NULL. Параметры Тип: Строка. Выражение, которое надо вычислить. <Группировка> Тип: Строка. Содержит имя группировки, в контексте которой необходимо вычислить выражение. В случае если в качестве имени группировки используется пустая строка, вычисление будет выполнено в контексте текущей группировки. В случае если в качестве имени группировки будет использована строка ОбщийИтог, вычисление будет выполнено в контексте общего итога. В остальных случаях вычисление будет выполняться в контексте родительской группировки с таким именем. Например: Сумма(Продажи.СуммаОборот)/Вычислить(“Сумма(Продажи.СуммаОборот)”, “ОбщийИтог”) В данном примере в результате получится отношение суммы по полю Продажи.СуммаОборот записи группировки к сумме того же поля во всей компоновке; Тип: Строка. Параметр может принимать следующие значения:    ОбщийИтог — выражение будет вычисляться для всех записей группировки.    Иерархия — выражение будет вычисляться для родительской иерархической записи, если таковая имеется, и для всей группировки, если родительской иерархической записи не имеется.    Группировка — выражение будет вычисляться для текущей групповой записи группировки.    ГруппировкаНеРесурса — при вычисление функции для групповой записи по ресурсам, выражение будет вычислено для первой групповой записи исходной группировки. При вычислении функции ВычислитьВыражение со значением ГруппировкаНеРесурса для групповых записей, не являющихся группировками по ресурсам, функция вычисляется так же, как бы она вычислялась в том случае, если значение параметра было равно значению Группировка. Компоновщик макета компоновки данных при генерации макета компоновки данных при выводе в макет поля-ресурса, по которому выполняется группировка, помещает в макет выражение, вычисляемое при помощи функции ВычислитьВыражение, с указанием параметраГруппировкаНеРесурса. Для остальных ресурсов в группировке по ресурсу помещаются обычные выражения ресурсов. <Начало> Тип: Строка. Указывает, с какой записи нужно начинать фрагмент, в котором рассчитывать агрегатные функции выражения и из какой записи получать значения полей вне агрегатных функций. Значение может быть одним из следующих:    Первая (First). Необходимо получать первую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение от начала группировки. Получаемое значение должно целым быть числом, больше нуля. Например, Первая – получение третьей записи от начала группировки. Если первая запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3, а требуется получитьПервая, то считается, что записей нет.    Последняя (Last). Необходимо получить последнюю запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение от конца группировки. Получаемое значение должно целым быть числом, больше нуля. Например,Последняя – получение третьей записи от конца группировки. Если последняя запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3, а требуется получитьПоследняя, то считается, что записей нет.    Предыдущая (Previous). Необходимо получить предыдущую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение назад от текущей записи группировки. Например, Предыдущая – получение предыдущей от предыдущей записи. Если предыдущая запись выходит за пределы группировки (например, для второй записи группировки требуется получить Предыдущая, то получается первая запись группировки. При получении предыдущей записи для итога по группировке считается, что получается первая запись.    Следующая (Next). Необходимо получить следующую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение вперед от текущей записи группировки. Например, Следующая – получение следующей от следующей записи. Если следующая запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3 и для третьей записи получают Следующая, то считается, что записей нет. При получении следующей записи для итога по группировке считается, что записи нет.    Текущая (Current). Необходимо получить текущую запись. При получении для итога по группировке получается первая запись.    ОграничивающееЗначение (BoundaryValue). Необходимость получить запись по указанному значению. После слова ОграничивающееЗначениев скобках нужно указать выражение, со значения которого нужно начинать фрагмент, первого поля упорядочивания. В качестве записи будет получаться первая запись, значение поля упорядочивания у которой больше или равно указанному значению. Например, если в качестве поля упорядочивания используется поле Период, и оно имеет значения 01.01.2010, 01.02.2010, 01.03.2010, и требуется получить ОграничивающееЗначение(ДатаВремя(2010, 1, 15)), то будет получена запись с датой 01.02.2010. <Конец> Тип: Строка. Указывает, до какой записи нужно продолжать фрагмент, в котором рассчитывать агрегатные функции выражения. Значение может быть одним из следующих:    Первая (First). Необходимо получать первую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение от начала группировки. Получаемое значение должно целым быть числом, больше нуля. Например, Первая – получение третьей записи от начала группировки. Если первая запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3, а требуется получитьПервая, то считается, что записей нет.    Последняя (Last). Необходимо получить последнюю запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение от конца группировки. Получаемое значение должно целым быть числом, больше нуля. Например,Последняя – получение третьей записи от конца группировки. Если последняя запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3, а требуется получитьПоследняя, то считается, что записей нет.    Предыдущая (Previous). Необходимо получить предыдущую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение назад от текущей записи группировки. Например, Предыдущая – получение предыдущей от предыдущей записи. Если предыдущая запись выходит за пределы группировки (например, для второй записи группировки требуется получить Предыдущая, то получается первая запись группировки. При получении предыдущей записи для итога по группировке считается, что получается первая запись.    Следующая (Next). Необходимо получить следующую запись группировки. После слова в скобках можно указывать выражение, результат которого будет использоваться как смещение вперед от текущей записи группировки. Например, Следующая – получение следующей от следующей записи. Если следующая запись выходит за пределы группировки, то считается, что записей нет. Например, если записей 3 и для третьей записи получают Следующая, то считается, что записей нет. При получении следующей записи для итога по группировке считается, что записи нет.    Текущая (Current). Необходимо получить текущую запись. При получении для итога по группировке получается первая запись.    ОграничивающееЗначение (BoundaryValue). Необходимость получить запись по указанному значению. После слова ОграничивающееЗначениев скобках нужно указать выражение, со значения которого нужно начинать фрагмент, первого поля упорядочивания. В качестве записи будет получаться первая запись, значение поля упорядочивания у которой больше или равно указанному значению. Например, если в качестве поля упорядочивания используется поле Период, и оно имеет значения 01.01.2010, 01.02.2010, 01.03.2010, и требуется получить ОграничивающееЗначение(ДатаВремя(2010, 1, 15)), то будет получена запись с датой 01.02.2010. <Сортировка> Тип: Строка. Перечисляются выражения, разделенные запятыми, которые описываютправила упорядочивания. Если не указана, то упорядочивание выполняется также как и у группировки, для которой вычисляется выражение. После каждого выражения можно указать ключевое слово Возр (для упорядочивания по возрастанию), Убыв (для упорядочивания по убывания) и Автоупорядочивание (для упорядочивания ссылочных полей по полям, по которым нужно упорядочивать объект, на который выполняется ссылка). Слово Автоупорядочивание может использоваться как со словом Возр, так и со словом Убыв. <ИерархическаяСортировка> Тип: Строка. Аналогично параметру Сортировка. Применяется для упорядочивания иерархических записей. Если не указано, компоновщик макета генерирует упорядочивание в соответствии с упорядочиванием, указанным в параметре Сортировка. Тип: Строка. Указывает правило определения предыдущей или следующий записи в случае если есть несколько записей с одинаковым значением упорядочивания:    Отдельно (Separately) обозначает, что для определения предыдущей и следующей записей используется последовательность упорядоченных записей. Значение по умолчанию.    Вместе (Together) обозначает, что предыдущая и следующие записи определяются на основании значений выражений упорядочивания. Например, если полученная последовательность упорядочена по дате: №    Дата    ФИО    Значение 1    01 января 2001 года    Иванов М.    10 2    02 января 2001 года    Петров С.    20 3    03 января 2001 года    Сидоров Р.    30 4    04 января 2001 года    Петров С.    40 Если значение параметра равно Отдельно, то: §  предыдущей записью к записи 3 будет запись 2. §  если расчетный фрагмент определяется как Текущая, Текущая (соответственно, параметры Начало и Конец), то для записи 2 этот фрагмент будет состоять из одной записи 2. Выражение ВычислитьВыражение(«Сумма(Значение)”, , , Текущая, Текущая) будет равно 20. Если значение параметра равно Вместе, то: §  предыдущей записью к записи 3 будет запись 1. §  если расчетный фрагмент определяется как Текущая, Текущая (соответственно, параметры Начало и Конец), то для записи 2 этот фрагмент будет состоять из записей 2 и 3. Выражение ВычислитьВыражение(«Сумма(Значение)”, , , Текущая, Текущая) будет равно 50. При указании значение параметра равного Вместе, в параметрах Начало и Конец нельзя указывать смещение для позиций Первая,Последняя, Предыдущая, Следующая. Пример: Если требуется рассчитать сумму с накоплением, то можно использовать следующее выражение: Если требуется получить значение группировки в предыдущей строке, то можно использовать следующее выражение:
#22 by fisher
Имелся в виду хотя бы один конкретный пример в контексте сабжевой задачи. Цель, напоминаю - получить список всех родителей текущего элемента справочника. Нарисуй, например, вычисляемое выражение, возвращающее сумму кодов всех родителей по каждому элементу справочника. Я не знаю, как это сделать. Хотя твоя копипаста встроенной справки для меня отнюдь не откровение.
Тэги: 1С 8
Ответить:
Комментарии доступны только авторизированным пользователям