3

如何使用 MDX 过滤两个成员属性?

在此处输入图像描述

目前我有以下解决方案。它有效,但我确信MDX查询会更有效率。

查询设计器中的数据集具有以下内容MDX以将成员属性包含为字段:

DIMENSION PROPERTIES MEMBER_CAPTION, MEMBER_UNIQUE_NAME, [Store].[Store].[Closed Date],[Store].[Store].[Opening Date]

我在数据集属性中使用两个过滤器,表达式如下:

    =Cint(Fields!Opening_Date.Value) 
    < 
    =Cint(Format(Today(), "yyyyMMdd"))

    =Cint(Fields!Closed_Date.Value) 
    >
    =Cint(Format(Today(), "yyyyMMdd"))
4

2 回答 2

1

我怀疑下面的表现会令人满意,但你可以试一试。

SELECT SomeDim.SomeHIerarchy.MEMBER 
HAVING 
Val(SomeDim.SomeHIerarchy.CURRENTMEMBER.Properties("Opening Date")) <  Format(now(), "dd-MM-yyyy")
Val(SomeDim.SomeHIerarchy.CURRENTMEMBER.Properties("Closing Date")) > Format(now(), "dd-MM-yyyy")
ON 1,
Measures.Foo on 0
FROM [Your Cube]
于 2015-12-11T17:34:35.470 回答
1

我发现使用过滤器是解决这个问题的最佳方法:

filter(
  [Store].[Store].members, [Store].[Store].Properties( "Opening Date" ) < Format(Now(),'yyyyMMdd') 
  and [Store].[Store].Properties( "Closed Date" ) > Format(Now(),'yyyyMMdd'))
)
于 2015-12-16T15:58:52.427 回答