成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

示例:C#通過AMO對象瀏覽SQL SERVER 2005 SSAS

開發(fā) 后端
本文介紹了C#通過AMO對象模型瀏覽SQL SERVER 2005 SSAS角色一例,希望對大家有所幫助。

用過SSAS的朋友都使用Visual Studio Business Intelligence Development Studio(BIDS)去創(chuàng)建以及管理所創(chuàng)建的Cube。但是如果只是想查看Cube下的某個(gè)角色包含的用戶以及權(quán)限,我們只能一遍遍的打開BIDS,忍受它的慢動作。更有甚者,如果要比較兩個(gè)Cube下所有角色及用戶是否一致,手工操作更是會讓人頭大?,F(xiàn)在,利用Microsoft提供的AMO對象模型,我們可以很輕松的對Cube進(jìn)行編程訪問,根據(jù)自身工作的需求,實(shí)在一些有用的工具,以提高工作效率,避免無聊的手工重復(fù)勞動。

Analysis Management Objects (AMO) 是SQL Server SSAS的對象模型庫,通過它可以方便的對SSAS里的對象進(jìn)行訪問及控制,包括Cube, DataSource, DataSourceView, Partition, Measure, Dimension, Assembly, Role以及Data Mining對象等。要使用它,必須在機(jī)器上找到SSAS的安裝路徑..\Microsoft SQL Server\90\SDK\Assemblies,把目錄中的Microsoft.AnalysisServices.Dll文件加載到項(xiàng)目的Reference列表中,AMO對象就是通過這個(gè)Dll文件進(jìn)行訪問的。

需要說明的一點(diǎn)是,AMO對象不能用來獲取Cube中的數(shù)據(jù),如果想要進(jìn)行數(shù)據(jù)查詢,則需要使用ADOMD.Net (Microsoft.AnalysisServices.AdomdClient).

下面,我們就簡要介紹一下如何利用AMO對象來訪問Cube。在把Microsoft.AnalysisServices.Dll加載到項(xiàng)目的引用以后,在代碼中我們需要引入命名空間:

  1. using Microsoft.AnalysisServices 

在此命名空間下,我們首先引入SSAS的Server對象,并建立連接:

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

與SSAS的服務(wù)器實(shí)例建立連接以后,我們要取得它的所有Database對象名稱:

  1. static public List< string> GetDatabaseCollection()  
  2.     {  
  3.         List< string> collect = new List< string>();  
  4.         foreach (Database db in server.Databases)  
  5.         {  
  6.             collect.Add(db.Name);  
  7.         }  
  8.         return collect;           

請注意,AMO中的Database對象并不是一般意義上的數(shù)據(jù)庫,而是一個(gè)容器,可以簡單的理解為我們的一個(gè)Business Intelligence項(xiàng)目就是一個(gè)Database容器,在Database對象內(nèi)容,包括了BI項(xiàng)目中的所有內(nèi)容 (Cube, dimension, data mining structure, data source, account, role) 。

接下來,根據(jù)所選擇的Database來獲得它的Cube對象,因?yàn)樵谝粋€(gè)Database下(一個(gè)BI項(xiàng)目中),我們可以建立多個(gè)Cube,所以在此先取得所有Cube的列表:

  1. static public List< string> GetCubeCollection(string databasename)  
  2. {  
  3.     List< string> collect = new List< string>();  
  4.     database = server.Databases[databasename];  
  5.     foreach (Cube cube in database.Cubes)  
  6.     {  
  7.         collect.Add(cube.Name);  
  8.     }  
  9.     return collect;  

在Cube對象中,我們可以取得CubePermission對象,角色Role就在CubePermission中,從這里就可以獲得指定Cube下所有的角色名稱列表:

  1. static public List< string> GetCubePermission(string cubename)  
  2.     {  
  3.         List< string> collect = new List< string>();  
  4.         cube = database.Cubes[cubename];  
  5.         foreach (CubePermission cp in cube.CubePermissions)  
  6.         {  
  7.             collect.Add(cp.Role.Name);  
  8.         }  
  9.         return collect;  
  10.     }  

到這里,我們其實(shí)就滿足了基本需求,可以很輕松地得到Cube下的角色列表,但是不同角色針對Dimension和Attribute其實(shí)是擁有不同的訪問權(quán)限。

  1. foreach (CubeDimensionPermission dp in cp.DimensionPermissions)  
  2. {  
  3.   foreach (AttributePermission ap in dp.AttributePermissions)  
  4.    {  
  5.     Label1.Text = ap.AllowedSet;  
  6.     Label2.Text = ap.DeniedSet;  
  7.     }  

利用CubeDimensionPermission下的AttributePermission對象,我們可以得到當(dāng)前角色的允許和拒絕的維度屬性值,得到了這個(gè)值,我們可以直接編程來檢查兩個(gè)Cube中的角色是否一致。

上面只是簡單介紹了利用AMO對象進(jìn)行SSAS服務(wù)器對象管理的一個(gè)例子,其實(shí)大家可以盡情發(fā)揮,利用AMO對象實(shí)現(xiàn)一些實(shí)用的工具來幫忙日常工作中對于SSAS的便捷管理。

附:AMO對象樹

AMO對象樹 

【編輯推薦】

  1. 學(xué)習(xí)C#消息:循序漸進(jìn)
  2. 解惑答疑:C#委托和事件
  3. 學(xué)習(xí)C#實(shí)現(xiàn)HTTP協(xié)議:多線程文件傳輸
  4. 進(jìn)一步接觸C#委托與事件
  5. 淺析四種C#轉(zhuǎn)換的區(qū)別
責(zé)任編輯:book05 來源: cnblogs
相關(guān)推薦

2011-03-29 15:27:26

SQL Server 動態(tài)管理

2011-08-30 14:40:46

SQL Server Oracle 10gC#源碼程序

2009-08-06 18:15:13

C# SQL Serv

2009-08-24 15:41:50

C#連接SQL Ser

2009-08-31 14:54:35

C#對象瀏覽器

2009-08-06 16:18:38

C#調(diào)用SQL存儲過程

2011-08-01 10:09:57

SSAS數(shù)據(jù)庫

2010-07-23 12:55:29

SQL Server

2010-07-19 11:28:14

SQL Server

2010-07-09 11:06:13

SQL Server

2009-08-17 18:30:29

C# SQL Serv

2010-07-13 09:12:56

SQL Server

2011-08-02 13:44:49

JSPJDBCSQL Server

2010-11-08 09:04:00

SQL Server

2011-04-18 13:02:08

SQL Server SQL Server

2011-02-28 17:41:20

SQL Server

2011-03-28 12:50:45

SQL Server CE基礎(chǔ)

2009-07-20 16:40:55

JDBC訪問SQL S

2010-06-17 15:09:49

SQL Server

2010-09-03 10:40:30

SQL刪除
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 在线视频第一页 | 少妇av片 | 在线电影日韩 | 精品一区二区久久 | 精品国产一区二区三区性色 | 亚洲网在线 | 99久久婷婷国产综合精品电影 | 国产午夜精品一区二区三区四区 | 天天噜天天干 | 国产精品欧美一区二区三区不卡 | 91久久久久久久久久久 | 国产精品一卡 | 黄色一级视频免费 | 日韩欧美视频在线 | 日韩三区在线观看 | 在线一区视频 | 成人中文网 | 午夜精品在线观看 | 毛片网站免费观看 | 青青草一区二区三区 | 亚洲视频在线免费观看 | 成年人在线观看视频 | 久久伊人精品 | 国产亚洲精品一区二区三区 | 欧美日韩久久久久 | 久久久成人动漫 | 国产精品久久久久一区二区三区 | 中文字幕韩在线第一页 | 国产视频久久 | 日韩福利视频 | 日本五月婷婷 | 国产在线高清 | 欧美一区二区在线 | 成年视频在线观看 | www.av7788.com| 国产精品极品美女在线观看免费 | www.久久| 一级片aaa | 国产激情视频在线免费观看 | 欧美日韩一卡 | 精品九九久久 |