编写MDX报表长久以来对于报表人员来说都比较痛苦. 当然如果你用查询设计器(Query Designer) 直接拖拉数据集那就很方便,但是你们有没有想过查询设计器是怎么创建MDX的.或者创建的参数是如何工作的? 我听到很多用Analysis Services 作为数据源的(包括我)报表人员说写参数太难了,所以他们用查询设计器做报表. 我想关键的问题是查询设计器做的MDX看起来要比实际上更复杂.如果你知道一些MDX基础,你应该能直接写MDX而不是用查询分析器 ,你就是喜欢用查询分析器也没关系.本文的目的是指导你写基础的MDX语句,并且参数化 .
我们会用到两个 MDX 函数 :
返回字符表达式指定的集合(MSDN的定义),其实就是把你写转为MDX集合.
返回字符表达式指定的成员(MSDN的定义).就是把你写的转为MDX成员.
我们先装下 Adventure Works cube,如果你没有的话可以从www.codeplex.com下载.假设你知道一些 Reporting Services一些基础支持 and not define each component of the tool that is not new for this example.
建立一个新的Report Server 项目和报表,并且使用Adventure Works cube作为数据源. 然后建立名为CategorySales 的数据集.在查询设计器里面点击设计模式(Design Mode)按钮,然后开始写查询. 下面是个无参数的查询例子.
Select [Measures].[Internet Sales Amount] on Columns From [Adventure Works]
这个查询返回总销量,不过就报表本身而言它没任何意义.让我们添加销量对应的产品目录.
Select [Measures].[Internet Sales Amount] on Columns, [Product].[Category].Children on Rows From [Adventure Works]
这对我们假想的用户需求来说还不够少,除了看所有产品的销量以外,他们还想弄个参数,使他们可以从下拉框中选择想要看的类型 .为此,我们点击查询参数按钮来创建一个参数.
点击确认以后,你需要修改MDX 来使用你创建的参数, 修改如下:
Select [Measures].[Internet Sales Amount] on Columns, StrToSet(@ProductCategory, Constrained) on Rows From [Adventure Works]
我们用 StrToSet 来转换用户选择的变量值,是的MDX可以理解它们. Constrained 标记表示要确保有一个成员在集合中.
点击OK,然后一路创建下去.. 你会注意到,ProductCategory的下拉框已经自动创建.
现在让我们进一步完善这个例子. 我们再添加两个函数,来创建一个日期范围.再次单击查询参数按钮,添加参数StartDate 和 EndDate ,然后引用 Date 维度和 Date属性. 默认值随便填.
在 MDX 里面添加where子句来限制时间范围. 我们用 StrToMember 来转换.
Select [Measures].[Internet Sales Amount] on Columns, StrToSet(@ProductCategory, Constrained) on Rows From [Adventure Works] Where StrToMember(@StartDate, Constrained) :StrToMember(@EndDate, Constrained)
下面是预览结果
原文连接 http://www.bidn.com/blogs/DevinKnight/ssis/6252/writing-parametrized-mdx-for-reporting-services