中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#中怎么通過AMO對象瀏覽SQL SERVER數據庫

發布時間:2021-07-08 14:55:31 來源:億速云 閱讀:201 作者:Leah 欄目:編程語言

這篇文章給大家介紹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數據庫就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

获嘉县| 墨竹工卡县| 修武县| 淮南市| 双桥区| 丰城市| 涞源县| 益阳市| 洪洞县| 紫金县| 杭锦后旗| 富顺县| 崇文区| 怀宁县| 梧州市| 尖扎县| 麟游县| 彭阳县| 行唐县| 桦川县| 扎鲁特旗| 公主岭市| 浦江县| 通化市| 锡林郭勒盟| 上犹县| 上饶市| 台北市| 凌云县| 新丰县| 凤台县| 泾川县| 昌宁县| 九江市| 北川| 思南县| 额尔古纳市| 边坝县| 崇义县| 错那县| 壶关县|