Как загружать и обрабатывать текстовые данные на верхних уровнях измерения в icCube?

Я хочу загрузить текстовые данные для любого члена в естественной иерархии в icCube, но я не могу отображать текстовые значения с помощью MDX для верхних уровней.

Рассмотрим следующую (естественную) иерархию, данные и ожидаемый результат:

введите описание изображения здесь (Это может выглядеть немного странно, но icCube позволяет оставить лист пустым для SUB013 и SUB014.)

Как вы можете видеть в желаемом результате на картинке выше, я ожидаю, что "вуаля" будет отображаться на SUB015.

Но я не могу заставить его работать. Смотрите результат, который я получаю с MDX: результат в icCube MDX

У меня есть следующие проблемы:

  1. значение пустое (я использовал тип агрегации без текста)
  2. Другое наблюдение состоит в том, что также сумма является пустой для типа агрегации без

Это как-то решаемо?

(заключенный в виде фрагмента - не запускаемый - схема, которую я использовал, которую вы можете загрузить в своем экземпляре icCube)

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<schemaFactory revisionNumber="77">
    <schemaDefinition name="text on sub-total" description="" group="Research" loadOnStartup="false">
        <activateIncrementalLoad>false</activateIncrementalLoad>
        <useUnknownMembersInFacts>false</useUnknownMembersInFacts>
        <autoCleanUpTableColumns>false</autoCleanUpTableColumns>
        <useFactPartitioning>false</useFactPartitioning>
        <callGarbageCollector>NONE</callGarbageCollector>
        <backup>NONE</backup>
        <nonEmptyCachePolicy>NONE</nonEmptyCachePolicy>
        <nonEmptyCacheType>REGULAR</nonEmptyCacheType>
        <nonEmptyCachePersistency>MEMORY</nonEmptyCachePersistency>
        <storagePolicy>DEFAULT</storagePolicy>
        <hierarchyUniqueNameStyle>IncludeDimensionName</hierarchyUniqueNameStyle>
        <inMemoryDS name="manual">
            <memoryDataTable tableName="data" rowLimit="-1" id="3c476e37-708d-4066-831c-89508134beb7">
                <column name="dim" tableType="STRING" type="STRING" selected="true" primaryKey="false" nullObjectAsString=""/>
                <column name="costs" tableType="STRING" type="DOUBLE" selected="true" primaryKey="false" nullObjectAsString=""/>
                <column name="text" tableType="STRING" type="STRING" selected="true" primaryKey="false" nullObjectAsString=""/>
                <addRowNumber>false</addRowNumber>
                <stringDateConverter></stringDateConverter>
                <trimStrings>true</trimStrings>
                <columnSeparator>\t</columnSeparator>
                <commentMarker>#</commentMarker>
                <dataAsString>dim costs text
CHILD001  
CHILD002  
CHILD003 10 hi
CHILD004  
CHILD005  
SUB013 59 salut
SUB014 69 bonjour
SUB015 180 voila
</dataAsString>
            </memoryDataTable>
            <memoryDataTable tableName="dim" rowLimit="-1" id="373a4b14-5b7d-441d-91c0-caabeb670936">
                <column name="SubTotal" tableType="STRING" type="STRING" selected="true" primaryKey="false" nullObjectAsString=""/>
                <column name="Leaf" tableType="STRING" type="STRING" selected="true" primaryKey="false" nullObjectAsString=""/>
                <addRowNumber>false</addRowNumber>
                <stringDateConverter></stringDateConverter>
                <trimStrings>true</trimStrings>
                <columnSeparator>\t</columnSeparator>
                <commentMarker>#</commentMarker>
                <dataAsString>SubTotal Leaf
SUB013 
SUB014 
SUB015 CHILD001
SUB015 CHILD002
SUB015 CHILD003
SUB015 CHILD004
SUB015 CHILD005
</dataAsString>
            </memoryDataTable>
        </inMemoryDS>
        <multiLevelDimension dataTableId="373a4b14-5b7d-441d-91c0-caabeb670936" isTimeDimension="false" isDefaultTimeDimension="false" isIndexingByRange="false" unknownMemberName="" id="6b08783b-b33c-4499-b253-212753be23fd" name="Dim">
            <multiLevelHierarchy hasAllLevel="true" allLevelName="All-L" allMemberName="All-M" name="Dim" isDefault="true" defaultMemberName="">
                <factAggregationType>MEMBER_AND_ANCESTORS</factAggregationType>
                <level name="subtotal" nameUnique="true" nameUniqueInParent="false" keyUnique="true" ignoreNameCollision="false">
                    <column name="SubTotal"/>
                    <nameCol name="SubTotal"/>
                    <orderType>NONE</orderType>
                    <orderKind>ASC</orderKind>
                </level>
                <level name="leaf" nameUnique="true" nameUniqueInParent="false" keyUnique="true" ignoreNameCollision="false">
                    <column name="Leaf"/>
                    <nameCol name="Leaf"/>
                    <orderType>NONE</orderType>
                    <orderKind>ASC</orderKind>
                </level>
            </multiLevelHierarchy>
        </multiLevelDimension>
        <cube id="1c361ef2-ebba-475f-9cc8-83910e4530e2" name="data" description="">
            <defaultFacts measureGroupName="Facts" partitioningLevelName="" partitioningType="NONE" newGeneration="true" dataTableId="3c476e37-708d-4066-831c-89508134beb7" aggregateDataSourceFacts="false" unresolvedRowsBehavior="ERROR">
                <rowFactAggregationType>ADD_ROW</rowFactAggregationType>
                <measure name="costs sum" aggregationType="SUM">
                    <rollupHierarchy></rollupHierarchy>
                    <dataColumn name="costs"/>
                    <cellProperties></cellProperties>
                    <emptyIsZero>false</emptyIsZero>
                </measure>
                <measure name="costs max" aggregationType="MAX">
                    <rollupHierarchy></rollupHierarchy>
                    <dataColumn name="costs"/>
                    <cellProperties></cellProperties>
                    <emptyIsZero>false</emptyIsZero>
                </measure>
                <measure name="costs no agg" aggregationType="NONE">
                    <rollupHierarchy></rollupHierarchy>
                    <dataColumn name="costs"/>
                    <cellProperties></cellProperties>
                    <emptyIsZero>false</emptyIsZero>
                </measure>
                <measure name="text max" aggregationType="MAX">
                    <rollupHierarchy></rollupHierarchy>
                    <dataColumn name="text"/>
                    <cellProperties></cellProperties>
                    <emptyIsZero>false</emptyIsZero>
                </measure>
                <measure name="text no agg" aggregationType="NONE">
                    <rollupHierarchy></rollupHierarchy>
                    <dataColumn name="text"/>
                    <cellProperties></cellProperties>
                    <emptyIsZero>false</emptyIsZero>
                </measure>
                <links dimensionId="6b08783b-b33c-4499-b253-212753be23fd">
                    <viewLinks type="ALL_LEVELS">
                        <toColumns name="dim"/>
                    </viewLinks>
                </links>
            </defaultFacts>
        </cube>
        <localization enabled="false"/>
        <script>
            <content>
            </content>
        </script>
    </schemaDefinition>
</schemaFactory>

1 ответ

Решение

В icCube значение узла, даже если оно листовое, может быть результатом агрегации по нескольким строкам фактов. Когда вы указываете NO_AGGREGATION, в качестве метода агрегирования возвращается NULL, если в игре более одной строки.

Например, у SUB015 есть дочерний элемент со значением CHILD003. И размерность определяется с помощью Fact Aggr. Напечатайте 'как' Члены и Предки '.

Два решения:

1) Добавьте свойство члена Dimension, полученное с использованием вычисляемого члена.

2) Используйте измерение с "Fact Aggr. Напечатайте ' as 'Members', но вы получите неправильную стоимость.

Другие вопросы по тегам