下面,我们就简要介绍一下如何利用AMO对象来访问Cube。在把Microsoft.AnalysisServices.Dll加载到项目的引用以后,在代码中我们需要引入命名空间:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)using Microsoft.AnalysisServices
在此命名空间下,我们首先引入SSAS的Server对象,并建立连接:
SSAS的服务器实例建立连接以后,我们要取得它的所有Database对象名称:
String connectstring = Data Source = ServerName;Provider=msolap;与
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)static public Liststring GetDatabaseCollection()
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)
请注意,AMO中的Database对象并不是一般意义上的数据库,而是一个容器,可以简单的理解为我们的一个Business Intelligence项目就是一个Database容器,在Database对象内容,包括了BI项目中的所有内容 (Cube, dimension, data mining structure, data source, account, role) 。
接下来,根据所选择的Database来获得它的Cube对象,因为在一个Database下(一个BI项目中),我们可以建立多个Cube,所以在此先取得所有Cube的列表:Cube对象中,我们可以取得CubePermission对象,角色Role就在CubePermission中,从这里就可以获得指定Cube下所有的角色名称列表:
static public Liststring GetCubeCollection(string databasename)在
到这里,我们其实就满足了基本需求,可以很轻松地得到Cube下的角色列表,但是不同角色针对Dimension和Attribute其实是拥有不同的访问权限。
static public Liststring GetCubePermission(string cubename)(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/bianchengyuyan/)
foreach (CubeDimensionPermission dp in cp.DimensionPermissions)
{
foreach (AttributePermission ap in dp.AttributePermissions)
{
Label1.Text = ap.AllowedSet;
Label2.Text = ap.DeniedSet;
}
}
利用
CubeDimensionPermission下的AttributePermission对象,我们可以得到当前角色的允许和拒绝的维度属性值,得到了这个值,我们可以直接编程来检查两个Cube中的角色是否一致。
上面只是简单介绍了利用AMO对象进行SSAS服务器对象管理的一个例子,其实大家可以尽情发挥,利用AMO对象实现一些实用的工具来帮忙日常工作中对于SSAS的便捷管理。
附:AMO对象树