在SQL Server 2005中,如何编写查询来列出所有登录名、它们的服务器角色、所有数据库中对应的用户、数据库角色?
我不清楚SQL Server 2005或2008中与安全相关的目录视图。我想在一个查询中列出所有登录名、它们的服务器角色、它们在所有数据库中的对应用户、所有数据库角色。我该如何编写查询?
我知道有一些目录视图可以使用,但我不熟悉它们的关系。这些目录视图包括:sys.database_role_member、sys.database_principals、sys.server_role_member、sys.server_principals。
谢谢。
I'm not clear about the security-related catalog views in SQL Server 2005 or 2008. I want to list all logins, their server roles, their correspond users in all database, all database roles in one query. How can I write the query?
I know there are some catalog views to use, but I'm not familiar with their relation. These catalog views include: sys.database_role_member, sys.database_principals, sys.server_role_member, sys.server_principals.
Thanks.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您无法通过一个查询列出所有数据库,因为该列表是动态的。最好的选择是使用
sp_msforeachdb
并批量构造结果并返回它:一旦找到正确的结果集,您就可以扩展它以包括服务器角色和数据库角色成员资格形状将所有信息聚合在一个表中。
You cannot have one query list all databases because the list is dynamic. Your best bet is to use
sp_msforeachdb
and have a batch construct the result and return it:You can extend this to include the server roles and database roles memberships once you figure out a proper result set shape to aggregate all that information in a single table.
以下查询将列出所有登录名及其分配的服务器级角色。
Here is a query that will list all logins with their assigned server-level roles.