C#通过AMO对象模型浏览SQL SERVER 2005 SSAS角色一例

2016-02-19 12:23 47 1 收藏

关注图老师设计创意栏目可以让大家能更好的了解电脑,知道有关于电脑的更多有趣教程,今天给大家分享C#通过AMO对象模型浏览SQL SERVER 2005 SSAS角色一例教程,希望对大家能有一点小小的帮助。

【 tulaoshi.com - 编程语言 】

用过SSAS的朋友都使用Visual Studio Business Intelligence Development Studio(BIDS)去创建以及管理所创建的Cube。但是如果只是想查看Cube下的某个角色包含的用户以及权限,我们只能一遍遍的打开BIDS,忍受它的慢动作。更有甚者,如果要比较两个Cube下所有角色及用户是否一致,手工操作更是会让人头大。现在,利用Microsoft提供的AMO对象模型,我们可以很轻松的对Cube进行编程访问,根据自身工作的需求,实在一些有用的工具,以提高工作效率,避免无聊的手工重复劳动。 

Analysis Management Objects (AMO) 是SQL Server SSAS的对象模型库,通过它可以方便的对SSAS里的对象进行访问及控制,包括Cube, DataSource, DataSourceView, Partition, Measure, Dimension, Assembly, Role以及Data Mining对象等。要使用它,必须在机器上找到SSAS的安装路径..Microsoft SQL Server90SDKAssemblies,把目录中的Microsoft.AnalysisServices.Dll文件加载到项目的Reference列表中,AMO对象就是通过这个Dll文件进行访问的。

  需要说明的一点是,AMO对象不能用来获取Cube中的数据,如果想要进行数据查询,则需要使用ADOMD.Net (Microsoft.AnalysisServices.AdomdClient).

下面,我们就简要介绍一下如何利用AMO对象来访问Cube。在把Microsoft.AnalysisServices.Dll加载到项目的引用以后,在代码中我们需要引入命名空间:

 

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)using Microsoft.AnalysisServices


在此命名空间下,我们首先引入SSAS的Server对象,并建立连接: 

SSAS的服务器实例建立连接以后,我们要取得它的所有Database对象名称:

String connectstring = Data Source = ServerName;Provider=msolap;
Server ssasServer = New Server();
ssasServere.Connect(connectstring);

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

 

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

 

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)static public Liststring GetDatabaseCollection()
    {
        Liststring collect = new Liststring();
        foreach (Database db in server.Databases)
        {
            collect.Add(db.Name);
        }
        return collect;         
}

 

(本文来源于图老师网站,更多请访问http://www.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)
    {
        Liststring collect = new Liststring();
        database = server.Databases[databasename];
        foreach (Cube cube in database.Cubes)
        {
            collect.Add(cube.Name);
        }
        return collect;
}

 到这里,我们其实就满足了基本需求,可以很轻松地得到Cube下的角色列表,但是不同角色针对Dimension和Attribute其实是拥有不同的访问权限。

static public Liststring GetCubePermission(string cubename)
    {
        Liststring collect = new Liststring();
        cube = database.Cubes[cubename];
        foreach (CubePermission cp in cube.CubePermissions)
        {
            collect.Add(cp.Role.Name);
        }
        return collect;
    }

 

(本文来源于图老师网站,更多请访问http://www.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对象树

来源:http://www.tulaoshi.com/n/20160219/1600757.html

延伸阅读
标签: PS PS教程
本教程为 www.jcwcn.com 中国 专栏作家 叶冷 原创,如转载请保留这段话: 此照片由于光线较强,帽子下的阴影过重,看不清人物的脸面。现在需要减淡阴影,恢复人物的脸面。 screen.width-500)this.style.width=screen.width-500;" border=0 pop="按此在新窗口浏览图片"> 1、新建一个图层,按ctrl+alt+~键选取高光,大家看,蚂蚁先出现...
SQL Server 数据平台 SQL Server 是一个全面的、集成的、端到端的数据解决方案,它为企业中的用户提供了一个安全、可靠和高效的平台用于企业数据管理和商业智能应用。SQL Server 2005 为IT专家和信息工作者带来了强大的、熟悉的工具,同时减少了在从移动设备到企业数据系统的多平台上创建、部署、管理及使用企业数据和分析应用程序的...
标签: SQLServer
SQL Server 2005的新功能为动态管理对象,它们是在指定时间返回某个数据库实例的特殊状态信息的数据库视图或函数。这些对象允许数据库管理员或开发者对数据库服务器进行高效监控。动态管理对象取代了SQL Server以前版本中的许多系统表格,但也为数据库管理员提供更多观测手段。 服务器上需要监控的内容,几乎都有对应的动态管理对象。既然有这...
执行环境是SQL Server中设定用户权限的认证方式,例如,当您登录到SQL Server的时候,登录账户就被赋予了一定的权限,其中可能包括登录的功能、访问数据库以及在数据库中执行某些操作的功能。 SQL Server 2005包含了EXECUTE AS语句,通过使用EXECUTE AS语句,您可以为批处理和过程转换执行环境,这样,调用该批处理或过程的用户就可以...
本文介绍了 C# 下关于 单例 的三种实现方法。 最普通的一种: 以下是引用片段: using System; public class Singleton { private static Singleton instance; private Singleton() {} public static Singleton Instance { get ...

经验教程

185

收藏

75
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部