sys.database_role_members (Transact-SQL)
适用于:SQL Server(所有受支持的版本)
Azure SQL 数据库
Azure SQL 托管实例
Azure Synapse Analytics
Analytics Platform System (PDW)
为每个数据库角色的每个成员返回一行。 数据库用户、应用程序角色和其他数据库角色可以是数据库角色的成员。 若要将成员添加到角色,请使用具有选项的 ADD MEMBER
ALTER ROLE 语句。 联接sys.database_principals以返回值的名称principal_id
。
列名称 | 数据类型 | 说明 |
---|---|---|
role_principal_id | int | 角色的数据库主体 ID。 |
member_principal_id | int | 成员的数据库主体 ID。 |
权限
任何用户都可以查看自己的成员身份。 若要查看其他角色成员身份,需要固定数据库角色或VIEW DEFINITION
数据库中的成员身份db_securityadmin
。
目录视图中仅显示用户拥有的安全对象的元数据,或用户对其拥有某些权限的安全对象的元数据。 有关详细信息,请参阅 Metadata Visibility Configuration。
示例
以下查询返回数据库角色的成员。
SELECT DP1.name AS DatabaseRoleName,
isnull (DP2.name, 'No members') AS DatabaseUserName
FROM sys.database_role_members AS DRM
RIGHT OUTER JOIN sys.database_principals AS DP1
ON DRM.role_principal_id = DP1.principal_id
LEFT OUTER JOIN sys.database_principals AS DP2
ON DRM.member_principal_id = DP2.principal_id
WHERE DP1.type = 'R'
ORDER BY DP1.name;
另请参阅
安全性目录视图 (Transact-SQL)
主体(数据库引擎)
目录视图 (Transact-SQL)
ALTER ROLE (Transact-SQLL)
sys.server_role_members (Transact-SQL)