Поделиться через


Работа с функцией RollupChildren (многомерные выражения)

Функция RollupChildren многомерных выражений вычисляет свертку потомков некоторого элемента, применяя различные унарные операторы к каждому потомку, и возвращает результат этой свертки в виде числа. Унарный оператор может браться из свойства, связанного с элементом-потомком, или же оператор может быть строковым выражением, непосредственно заданным для этой функции.

Примеры функции RollupChildren

Применение функции RollupChildren в инструкциях многомерных выражений объяснить просто, однако действие этой функции на запросы многомерных выражений может быть разнообразным.

Воздействие функции RollupChildren осуществляется в запросах многомерных выражений, предназначенных для выполнения выборочного анализа существующих данных куба. Например, в следующей таблице перечисляются элементы-потомки для элемента-родителя «Чистая выручка от продаж», а в скобках показаны их унарные операторы (представленные свойством элементов UNARY_OPERATOR).

Родительский элемент

Дочерний элемент

Чистая выручка от продаж

Внутренние продажи (+)

Внутренние возвраты (-)

Зарубежные продажи (+)

Зарубежные возвраты (-)

Родительский элемент «Чистая выручка от продаж» в данный момент предоставляет сумму чистых продаж минус валовые внутренние и внешние продажи, причем вычитание внутренних и внешних возвратов производится как часть выполнения этой свертки.

Однако предположим, что надо быстро получить оценку прироста на 10 % внутренних и внешних валовых продаж без учета внутренних и внешних возвратов. Для вычисления этого значения можно воспользоваться функцией RollupChildren, применяя один из двух методов: с использованием пользовательского свойства элемента или функции IIf.

Применение пользовательского свойства элемента

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

Оператор

Результат

+

сумма = сумма + текущий дочерний элемент

-

сумма = сумма - текущий дочерний элемент

*

сумма = сумма * текущий дочерний элемент

/

сумма = сумма / текущий дочерний элемент

~

Дочерний элемент не используется в свертке. Значение дочернего элемента игнорируется.

Например, можно было бы создать свойство элемента с именем SALES_OPERATOR, и этому свойству элемента присваивались бы следующие унарные операторы — см. таблицу ниже.

Родительский элемент

Дочерний элемент

Чистая выручка от продаж

Внутренние продажи (+)

Внутренние возвраты (~)

Зарубежные продажи (+)

Зарубежные возвраты (~)

С помощью нового свойства элемента следующая инструкция многомерных выражений быстро и эффективно выполнит операцию прогнозирования валовых продаж (без учета внешних и внутренних возвратов):

RollupChildren([Net Sales], [Net Sales].CurrentMember.Properties("SALES_OPERATOR")) * 1.1

При вызове этой функции в сумму войдет значение каждого дочернего элемента, к которому будет применен оператор, хранящийся в данном свойстве элемента. Элементы для внутренних и внешних возвратов не учитываются, а полное значение свертки вычисляется по функции RollupChildren, умноженной на коэффициент 1,1.

Применение функции IIf

Если операция примера нетривиальна или если операция применяется только к одному запросу многомерных выражений, то можно использовать функцию IIf с функцией свертки RollupChildren для получения того же результата. Следующий запрос многомерных выражений дает тот же результат, что и описанный выше запрос многомерных выражений, но данный запрос выполняется без обращения к пользовательскому свойству элемента:

RollupChildren([Net Sales], IIf([Net Sales].CurrentMember.Properties("UNARY_OPERATOR") = "-", "~", [Net Sales].CurrentMember.Properties("UNARY_OPERATOR))) * 1.1

Инструкция многомерных выражений анализирует унарный оператор дочернего элемента. Если унарный оператор применяется для вычитания (как в случае элементов с внутренними и внешними возвратами), то функция IIf заменяет унарный оператор тильду (~). В противном случае функция IIf использует унарный оператор дочернего элемента. Наконец вычисленное значение суммы свертки умножается на коэффициент 1,1 для получения значения прогнозируемых валовых внутренних и внешних продаж.