我希望一组用户对SQL Server上所有数据库的所有表和视图具有只读访问权限(我正在使用SS2008)。我希望这些用户对所有未来的表和视图具有只读访问权限。
你会如何设置?
答案 0 :(得分:11)
将用户添加到db_datareader
角色
例如
exec sp_addrolemember 'db_datareader',YourLogin
有关db_datareader
的信息:http://msdn.microsoft.com/en-us/library/ms188629(SQL.90).aspx
答案 1 :(得分:1)
DECLARE @dbname VARCHAR(50)
DECLARE @statement NVARCHAR(max)
DECLARE db_cursor CURSOR
LOCAL FAST_FORWARD
FOR SELECT name FROM MASTER.dbo.sysdatabases OPEN db_cursor
FETCH NEXT FROM db_cursor INTO @dbname
WHILE @@FETCH_STATUS = 0
BEGIN
/* This sentence will be executed to gran the privileges. */
SELECT @statement = 'use ['+@dbname+']; '+'EXEC sp_addrolemember N''db_datareader'', N''userPeter''';
EXEC sp_executesql @statement
FETCH NEXT FROM db_cursor INTO @dbname
END
在显示userPeter
的位置,您必须填写用户名。
答案 2 :(得分:0)
您应该只能将用户添加到每个数据库中的db_datareader数据库角色。您可以编写一个脚本来遍历数据库并为您完成。