在MDX查询中使用变量

时间:2015-01-12 12:35:13

标签: ssis sql-server-2008-r2 mdx

我有一个MDX查询如下

 SELECT NON EMPTY 
 {[Measures].[Total  Value] } 
 DIMENSION PROPERTIES CHILDREN_CARDINALITY, 
 PARENT_UNIQUE_NAME ON COLUMNS, 
 NON EMPTY 
 {      
   CROSSJOIN(    
          {[Supplier].[Supplier Name].[All]},
          {[Warehouse].[Warehouses].[All]},
          {[Buyer].[Business Unit].[All]}
   ),
   CROSSJOIN(
          {[Supplier].[Supplier Name].[All].Children},
          {[Warehouse].[Warehouses].[All].Children},
          {[Buyer].[Business Unit].[All].Children}
   )
} 
DIMENSION PROPERTIES CHILDREN_CARDINALITY, 
PARENT_UNIQUE_NAME ON ROWS FROM [InventoryAge]
WHERE ( [Calendar].[Report Days].[All Members].&[All].&[WantInReport].&[2].&[20141031] )

我在SSIS包中使用此查询并提取数据。我想使用SSIS包参数将值'20141031'(值等于当前日期)传递给查询。我怎样才能实现

1 个答案:

答案 0 :(得分:1)

MDX不接受参数。 SSRS有一些解决方法,但在SSIS的情况下,您需要将查询放入表达式并从那里填充日期。

它看起来像这样:

...
PARENT_UNIQUE_NAME ON ROWS FROM [InventoryAge]
WHERE ( [Calendar].[Report Days].[All Members].&[All].&[WantInReport].&[2].&[" 
+ @[User::MyStringDate] + "] )"

编辑:我还应该注意,您可以在MDX中找到今天的日期,在计算成员中使用该日期并将其与您的查询交叉连接。以下是有关此内容的更多信息: http://sqlblog.com/blogs/mosha/archive/2007/05/23/how-to-get-the-today-s-date-in-mdx.aspx