mondrian角色:按层次结构过滤并隐藏层次结构

时间:2020-11-12 16:40:59

标签: pentaho roles mondrian

我有一个具有不同客户端的数据库(表TD_CLIENTS),该客户端可以访问mondrian多维数据集。显然,我希望每个客户端只能看到自己的数据。

我已经通过每个客户的角色来完成此任务(我的客户很少,所以这是一个可以接受的折衷。无论如何,如果有人知道更好的方法,我会很高兴听到它):< / p>

<Schema name="my_schema" description="my  schema">
  <Dimension type="StandardDimension" visible="true" highCardinality="false" name="Clients">
    <Hierarchy name="Clients hierarchy" visible="true" hasAll="true">
      <Table name="td_clients" schema="public">
      </Table>
      <Level name="Client" visible="true" table="td_clients" column="client_id" nameColumn="client_name" type="String" uniqueMembers="false" levelType="Regular" hideMemberIf="Never">
      </Level>
    </Hierarchy>
  </Dimension>
  <Cube name="my cube" visible="true" cache="true" enabled="true">
    <Table name="my_facts_table" schema="public">
    </Table>
    <DimensionUsage source="Clients" name="Clients" visible="true" foreignKey="client_id" highCardinality="false">
    </DimensionUsage>
    <Measure name="my measure" column="amount" aggregator="sum" visible="true">
    </Measure>
  </Cube>
  <Role name="Client 2 test">
    <SchemaGrant access="all">
      <CubeGrant cube="my cube" access="all">
        <HierarchyGrant hierarchy="[Clients.Clients hierarchy]" topLevel="[Clients.Clients hierarchy].[Client]" bottomLevel="[Clients.Clients hierarchy].[Client]" rollupPolicy="partial" access="custom">
          <MemberGrant member="[Clients.Clients hierarchy].[A CERTAIN CLIENT]" access="all">
          </MemberGrant>
        </HierarchyGrant>
      </CubeGrant>
    </SchemaGrant>
  </Role>
</Schema>

但是现在,由于每个登录用户(与其客户端角色相关联)只能看到一个客户端,所以我想隐藏客户端层次结构。

我该怎么做?

谢谢你,问候!

1 个答案:

答案 0 :(得分:1)

您将要关闭:

添加第二个HierarchyGrant来限制其可见性,例如:

        <HierarchyGrant hierarchy="[Clients.Clients hierarchy]" rollupPolicy="partial" access="custom">
          <MemberGrant member="[Clients.Clients hierarchy].[A CERTAIN CLIENT]" access="all">
          </MemberGrant>
        </HierarchyGrant>
        <HierarchyGrant hierarchy="[Clients.Clients hierarchy]" rollupPolicy="partial" access="none">
        </HierarchyGrant>

但是,请记住,除非添加第二个(可见)维,否则jpivot之类的工具将无法工作。

相关问题