我正在开发一个SSAS项目,其中我需要在C#中获得表格多维数据集的完整用户列表。 目前我的工作方式是我可以获得角色,但数据不完整。当我调用Server.Database.Roles(简化为可读性)属性并通过它枚举时,我只获得ID,Name和CreatedTimeStamp。我所缺少的,至关重要的是会员,CellPermissions(DAX过滤器)以及这些成员的权限。 我目前在Server.Database.Cube中寻找的权限(读/写/管理员),但CubePermissions是空的......
在SSMS中,当我编写我的一个testroles时,该角色包含:
<ID>Role</ID>
<Name>TestRole</Name>
<Description>role for testing</Description>
<Members>
<Member>
<Name>THORVALDDATA\rj</Name>
<Sid>OMITTED</Sid>
</Member>
<Member>
<Name>THORVALDDATA\dp</Name>
<Sid>OMITTED</Sid>
</Member>
<Member>
<Name>THORVALDDATA\jtl</Name>
<Sid>OMITTED</Sid>
</Member>
</Members>
但如前所述,当我在代码中枚举它时,我不会得到成员和描述。
你们这些聪明的人能帮助我弄清楚这里出了什么问题吗?
我的所有代码:
RoleCollection roleCollection = _analysisServer.Databases[dbID].Roles;
Database database = _analysisServer.Databases[dbID];
Dictionary<string, CubeRole> roles = new Dictionary<string, CubeRole>();
foreach (Role role in roleCollection)
{
CubeRole cRole = new CubeRole();
cRole.ID = role.ID;
cRole.Name = role.Name;
cRole.Members = role.Members;
CubeCollection cubeCollection = _analysisServer.Databases[dbID].Cubes;
foreach (Cube cube in cubeCollection)
{
foreach (CubePermission cubePermission in cube.CubePermissions)
{
cRole.Filters = cubePermission.CellPermissions;
cRole.Permission.Add(cubePermission);
}
}
roles.Add(cRole.Name, cRole);
}
return roles;
答案 0 :(得分:0)
使用表格,您可以在服务器级别拥有管理员。在数据库级别,您只有3个内置权限:1)完全控制2)Process Database&amp; 3)阅读。您在数据库中创建的每个角色都可以选择这些权限。表格中没有立方体,所以你只有2个级别,服务器和数据库。 MSDN是理解权限的良好起点。表格https://msdn.microsoft.com/en-us/library/hh213165.aspx
中的角色您可以遍历数据库的角色,以拉出每个角色中的角色成员以及与每个角色关联的权限:
//loop through database permissions
foreach (AMO.DatabasePermission dbp in Analysisdb.DatabasePermissions)
{
Console.Write(dbp.Role.Name); //role name
Console.Write(dbp.Read); // Is read role?
Console.Write(dbp.Process); // Is process role?
Console.Write(dbp.Administer); // Is Full control role?
//loop through database permissions role members
foreach (AMO.RoleMember rolemember in dbp.Role.Members)
{
Console.Write(rolemember.Name);
}
}
可以通过循环每个角色的每个维度来拉出每个维度的DAX表达式。下面的示例将获取codeplex AdventureWorks示例模型中Users角色的Currency维度的DAX表达式:
using (AMO.DimensionPermission dimensionPermission = AnalysisDb.Dimensions.GetByName("Currency").DimensionPermissions[0]);
Console.Write(dimensionPermission.AllowedRowsExpression);
有关表格AMO的更多信息,请参阅http://tabularamo2012.codeplex.com/SourceControl/latest#AMO2TabularV2/AMO2Tabular.RlsFunctions.cs。