0

我们经常负责在生产环境和开发环境之间备份和恢复数据库。此任务最繁琐的部分是当服务器位于不同区域时,在 SQL 中“一个一个”地重新创建数据库用户。

我正在寻找一种方法来检索特定数据库(Windows 用户和组、SQL 用户和角色)上的所有用户以及他们当前的权限级别,然后在数据库恢复后以某种方式使用这些结果重新创建权限。

谁能帮助我朝着正确的方向开始?

问候,

马修

4

2 回答 2

0

此网址应该可以帮助您入门。 http://support.microsoft.com/kb/918992 它是传输登录的组合,我个人为此使用 SSIS,然后根据上面的链接创建用户。

于 2013-09-27T14:44:37.053 回答
0

以下查询应该: 创建一个包含要执行的查询的临时表 使用查询加载该临时表以添加所有登录名 使用查询加载该临时表以添加所有用户(对于登录名) 使用查询加载该临时表以添加所有用户权限(表)

然后它会打印出所有这些语句,您应该能够将它们复制到新环境中的查询窗口并执行。

希望这对您来说是一个很好的起点。

if object_id('dbo.tempUsers') is not null
Drop table dbo.tempUsers

Create table tempUsers(ID int identity , Queries Varchar(255))

Insert into tempUsers(Queries)
select 'Create login [' + su.name + '] with password ' + su.password 
FROM sys.sysusers su

Insert into tempUsers(Queries)
select 'Create user [' + su.name + '] for login [' + su.password + ']'
FROM sys.sysusers su

Insert into tempUsers(Queries)
select 'GRANT ' + dp.permission_name collate latin1_general_cs_as
+ ' ON ' + s.name + '.' + o.name + ' TO '  + '[' + dpr.name + ']'
FROM sys.database_permissions AS dp
  INNER JOIN sys.objects AS o ON dp.major_id=o.object_id
  INNER JOIN sys.schemas AS s ON o.schema_id = s.schema_id
  INNER JOIN sys.database_principals AS dpr ON dp.grantee_principal_id=dpr.principal_id
where o.type = 'U'

declare @count int, @max int, @query Varchar(255)
set @count =1
set @max = (Select max(ID) from tempUsers)
set @query = (Select Queries from tempUsers where ID = @count)

while(@count < @max)
begin
print(@query)
set @count += 1
set @query = (Select Queries from tempUsers where ID = @count)
end
于 2013-09-27T19:16:40.647 回答