用過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加載到項目的引用以後,在代碼中我們需要引入命名空間:
using Microsoft.AnalysisServices
在此命名空間下,我們首先引入SSAS的Server對象,並建立連接:
SSAS的服務器實例建立連接以後,我們要取得它的所有Database對象名稱:
String connectstring = “Data Source = ServerName;Provider=msolap”;與
static public List<string> GetDatabaseCollection()
請注意,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