Пустые ячейки/смещение в отчете: как определить измерение и иерархию в кубе?

Я хочу проанализировать некоторую динамику некоторого процесса. Для этого я использую плагин аналитики Saiku CE для Pentaho Business Intelligence Server CE 5.0.1.

Существует таблица фактов и таблица измерений, которые используются для выполнения некоторых агрегаций. Измерения представляют собой иерархию "Год - Месяц - День".

Какой-то отчет я построил в двух разрезах - по годам и месяцам. Отчет выглядит следующим образом:

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

Данные, которые он показывает, верны:

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

Если я определяю независимое измерение «Месяц», отчет выглядит правильно:

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

Однако данные уже неверны:

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

Пробовал добавить обратное измерение "Месяц - Год", но не увидел никаких данных.

Есть ли способ определить измерение, в котором отчет не будет содержать пустых ячеек?


person Community    schedule 03.08.2016    source источник


Ответы (1)


Я нашел решение - проблема была в неправильном измерении даты.

См. подробный ответ здесь: Создайте диапазон дат в mysql

Новая схема Мондриана:

<Schema name="MondrianSchema">
  <Dimension type="TimeDimension" visible="true" highCardinality="false" name="X dimension">
    <Hierarchy name="X_hierarchy" visible="true" hasAll="true" primaryKey="date_key">
      <Table name="tbl_declaration_date_dim" schema="dbo">
      </Table>
      <Level name="Year" visible="true" table="tbl_declaration_date_dim" column="Year" nameColumn="Year" type="Numeric" uniqueMembers="true" levelType="TimeYears" hideMemberIf="Never">
      </Level>
      <Level name="Month" visible="true" table="tbl_declaration_date_dim" column="Month" nameColumn="Month" ordinalColumn="Month" type="Numeric" uniqueMembers="false" levelType="TimeMonths" hideMemberIf="Never">
      </Level>
      <Level name="Day" visible="true" table="tbl_declaration_date_dim" column="Day" nameColumn="Day" ordinalColumn="Day" type="Numeric" uniqueMembers="false" levelType="TimeDays" hideMemberIf="Never">
      </Level>
    </Hierarchy>
  </Dimension>
  <Dimension type="TimeDimension" visible="true" name="Y dimension">
    <Hierarchy name="Y_Hierarchy" visible="true" hasAll="true" primaryKey="date_key">
      <Table name="tbl_declaration_date_dim" schema="dbo" alias="">
      </Table>
      <Level name="Year" visible="true" table="tbl_declaration_date_dim" column="Year" nameColumn="Year" type="Numeric" uniqueMembers="true" levelType="TimeYears" hideMemberIf="Never">
      </Level>
      <Level name="Month" visible="true" table="tbl_declaration_date_dim" column="Month" nameColumn="Month" ordinalColumn="Month" type="Numeric" uniqueMembers="false" levelType="TimeMonths" hideMemberIf="Never">
      </Level>
      <Level name="Day" visible="true" table="tbl_declaration_date_dim" column="Day" nameColumn="Day" ordinalColumn="Day" type="Numeric" uniqueMembers="false" levelType="TimeDays" hideMemberIf="Never">
      </Level>
    </Hierarchy>
  </Dimension>
  <Cube name="tbl_application_cube" caption="..." visible="true" description="..." cache="true" enabled="true">
    <Table name="tbl_appl_olap_fact" schema="dbo">
    </Table>
    <DimensionUsage source="X dimension" name="X axis" visible="true" foreignKey="date_dim" highCardinality="false">
    </DimensionUsage>
    <DimensionUsage source="Y dimension" name="Y axis" visible="true" foreignKey="date_dim">
    </DimensionUsage>
    <Measure name="DeclarationCount" column="declaration_id" aggregator="count" visible="true">
    </Measure>
  </Cube>
</Schema>
person Community    schedule 03.08.2016