日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
示例:C#通過AMO對象瀏覽SQLSERVER2005SSAS

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

成都創(chuàng)新互聯(lián)公司是專業(yè)的靜海網(wǎng)站建設(shè)公司,靜海接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行靜海網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

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中的數(shù)據(jù),如果想要進行數(shù)據(jù)查詢,則需要使用ADOMD.Net (Microsoft.AnalysisServices.AdomdClient).

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

 
 
 
 
  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ù)器實例建立連接以后,我們要取得它的所有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;         
  9. }

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

接下來,根據(jù)所選擇的Database來獲得它的Cube對象,因為在一個Database下(一個BI項目中),我們可以建立多個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.     }

到這里,我們其實就滿足了基本需求,可以很輕松地得到Cube下的角色列表,但是不同角色針對Dimension和Attribute其實是擁有不同的訪問權(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.     }
  8. }

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

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

附:AMO對象樹


文章標(biāo)題:示例:C#通過AMO對象瀏覽SQLSERVER2005SSAS
當(dāng)前URL:http://www.dlmjj.cn/article/djiieih.html