SQL Server – 如何授予读取访问所有数据库到登录?
发布时间:2020-12-12 16:11:26 所属栏目:MsSql教程 来源:网络整理
导读:我需要对服务器上的所有300个数据库进行新的登录读取访问.如何在没有在用户映射区域中检查300个复选框的情况下完成此操作? 解决方法 一种方法是在SSMS的查询菜单中设置“结果到文本”,然后执行以下操作. 它实际上不会进行更改,但会生成一个脚本,供您查看和执
我需要对服务器上的所有300个数据库进行新的登录读取访问.如何在没有在用户映射区域中检查300个复选框的情况下完成此操作?
解决方法一种方法是在SSMS的查询菜单中设置“结果到文本”,然后执行以下操作.它实际上不会进行更改,但会生成一个脚本,供您查看和执行. SET NOCOUNT ON; DECLARE @user_name SYSNAME,@login_name SYSNAME; SELECT @user_name = 'user_name',@login_name = 'login_name' SELECT ' USE ' + QUOTENAME(NAME) + '; CREATE USER ' + QUOTENAME(@user_name) + ' FOR LOGIN ' + QUOTENAME(@login_name) + ' WITH DEFAULT_SCHEMA=[dbo]; EXEC sys.sp_addrolemember ''db_datareader'',''' + QUOTENAME(@user_name) + '''; EXEC sys.sp_addrolemember ''db_denydatawriter'',''' + QUOTENAME(@user_name) + '''; GO ' FROM sys.databases WHERE database_id > 4 AND state_desc = 'ONLINE' 或者您可以查看sys.sp_MSforeachdb as here或Aaron Bertrand的改进版本here 如果您在运行此操作时看不到所有字符,请打开“文本查询选项”,并检查“每列显示的最大字符数”设置.确保将其设置为足够大的值以显示所有字符. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |