SSAS : 使用.NET为SSAS编写自定义程序集(二)
上一篇,我们演示了一个简单的函数,AddPrefix,它的作用是为一个字符串添加一个前缀。
http://www.cnblogs.com/chenxizhang/archive/2009/06/27/1512163.html
下面为它添加一些灵活性
using System;
using System.Collections.Generic;
using System.Text;
namespace SSASStoreProcedure
{
public partial class StoredProcedures
{
/// <summary>
/// 这个方法用来添加一个前缀
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
public static string AddPrefix(string prefix,string input)
{
return string.Format("{0}:{1}", prefix, input);
}
}
}
现在,我们这个存储过程,它的前缀可以由用户指定,这显然更加好一些
WITH MEMBER [Measures].[TestMember]
AS
SSASStoreProcedure.AddPrefix('利润率',[Measures].[Total Sales Amount]/[Measures].[Total Product Cost])
SELECT [Customer].[Gender].Members ON 0,
{[TestMember],[Measures].[Total Sales Amount],[Measures].[Total Product Cost]} ON 1
FROM [Analysis Services Tutorial]
我们这次用来测试的脚本更加复杂一些:添加了一个计算成员,放在度量值组中。这个新的度量值,可以计算两个现有度量值的运算结果,并且添加相应的前缀
很显然,该方法内部的具体实现可以很复杂。
作为测试,我们还可以修改一下查询
WITH MEMBER [Measures].[TestMember]
AS
SSASStoreProcedure.AddPrefix('利润率',[Measures].[Total Sales Amount]/[Measures].[Total Product Cost])
SELECT [Customer].[Gender].Members ON 0,
{[Customer].[Education].CHILDREN}*{[TestMember],[Measures].[Total Sales Amount],[Measures].[Total Product Cost]} ON 1
FROM [Analysis Services Tutorial]