我们经常负责在生产环境和开发环境之间备份和恢复数据库。此任务最繁琐的部分是当服务器位于不同区域时,在 SQL 中“一个一个”地重新创建数据库用户。
我正在寻找一种方法来检索特定数据库(Windows 用户和组、SQL 用户和角色)上的所有用户以及他们当前的权限级别,然后在数据库恢复后以某种方式使用这些结果重新创建权限。
谁能帮助我朝着正确的方向开始?
问候,
马修
我们经常负责在生产环境和开发环境之间备份和恢复数据库。此任务最繁琐的部分是当服务器位于不同区域时,在 SQL 中“一个一个”地重新创建数据库用户。
我正在寻找一种方法来检索特定数据库(Windows 用户和组、SQL 用户和角色)上的所有用户以及他们当前的权限级别,然后在数据库恢复后以某种方式使用这些结果重新创建权限。
谁能帮助我朝着正确的方向开始?
问候,
马修
此网址应该可以帮助您入门。 http://support.microsoft.com/kb/918992 它是传输登录的组合,我个人为此使用 SSIS,然后根据上面的链接创建用户。
以下查询应该: 创建一个包含要执行的查询的临时表 使用查询加载该临时表以添加所有登录名 使用查询加载该临时表以添加所有用户(对于登录名) 使用查询加载该临时表以添加所有用户权限(表)
然后它会打印出所有这些语句,您应该能够将它们复制到新环境中的查询窗口并执行。
希望这对您来说是一个很好的起点。
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