广告
返回顶部
首页 > 资讯 > 精选 >C#中怎么通过AMO对象浏览SQL SERVER数据库
  • 340
分享到

C#中怎么通过AMO对象浏览SQL SERVER数据库

2023-06-17 22:06:20 340人浏览 八月长安
摘要

这篇文章给大家介绍C#中怎么通过AMO对象浏览SQL Server数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。用过SSAS的朋友都使用Visual Studio Business Intelligence De

这篇文章给大家介绍C#中怎么通过AMO对象浏览SQL Server数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

用过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 Server\90\SDK\Assemblies,把目录中的Microsoft.AnalysisServices.Dll文件加载到项目的Reference列表中,AMO对象就是通过这个Dll文件进行访问的。

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

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

using Microsoft.AnalysisServices

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

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

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

static public List< string> GetDatabaseCollection()      {          List< string> collect = new List< string>();          foreach (Database db in server.Databases)          {              collect.Add(db.Name);          }          return collect;           }

请注意,AMO中的Database对象并不是一般意义上的数据库,而是一个容器,可以简单的理解为我们的一个Business Intelligence项目就是一个Database容器,在Database对象内容,包括了BI项目中的所有内容 (Cube, dimension, data mining structure, data source, account, role) 。

接下来,根据所选择的Database来获得它的Cube对象,因为在一个Database下(一个BI项目中),我们可以建立多个Cube,所以在此先取得所有Cube的列表:

static public List< string> GetCubeCollection(string databasename)  {      List< string> collect = new List< string>();      database = server.Databases[databasename];      foreach (Cube cube in database.Cubes)      {          collect.Add(cube.Name);      }      return collect;

在Cube对象中,我们可以取得CubePermission对象,角色Role就在CubePermission中,从这里就可以获得指定Cube下所有的角色名称列表:

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

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

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对象树

C#中怎么通过AMO对象浏览SQL SERVER数据库

关于C#中怎么通过AMO对象浏览SQL SERVER数据库就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: C#中怎么通过AMO对象浏览SQL SERVER数据库

本文链接: https://www.lsjlt.com/news/294044.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C#中怎么通过AMO对象浏览SQL SERVER数据库
    这篇文章给大家介绍C#中怎么通过AMO对象浏览SQL SERVER数据库,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。用过SSAS的朋友都使用Visual Studio Business Intelligence De...
    99+
    2023-06-17
  • C#中怎么连接SQL Server数据库
    今天就跟大家聊聊有关C#中怎么连接SQL Server数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#连接SQL Server程序代码:using System.D...
    99+
    2023-06-17
  • SQL Server中怎么通过重建方式还原master数据库
    这期内容当中小编将会给大家带来有关SQL Server中怎么通过重建方式还原master数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具体内容如下1、备份maste...
    99+
    2022-10-18
  • 怎么在sql server中通过脚本进行数据库压缩全备份
    本篇文章为大家展示了怎么在sql server中通过脚本进行数据库压缩全备份,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。解决方案:通过with compressi...
    99+
    2022-10-18
  • SQL Server数据库中的存储过程是怎么样的
    SQL Server数据库中的存储过程是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。什么是存储过程如果你接触过其他的编程语言,那么就...
    99+
    2022-10-19
  • sql server中怎么通过查询分析器实现数据库备份与恢复
    这篇文章将为大家详细讲解有关sql server中怎么通过查询分析器实现数据库备份与恢复,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。sql server的...
    99+
    2022-10-18
  • 使用Python怎么实现SQL Server数据库的对象同步轻量级
    这期内容当中小编将会给大家带来有关使用Python怎么实现SQL Server数据库的对象同步轻量级,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1,表的存在依赖于sch...
    99+
    2022-10-18
  • SQL Server中怎么通过扩展存储过程实现数据库远程备份与恢复
    这篇文章将为大家详细讲解有关SQL Server中怎么通过扩展存储过程实现数据库远程备份与恢复,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。实现远程备份与恢...
    99+
    2022-10-18
  • VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办
    小编给大家分享一下VUE直接通过JS修改html对象的值导致没有更新到数据中怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作