-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathscript-users-and-roles.sql
More file actions
37 lines (34 loc) · 1 KB
/
script-users-and-roles.sql
File metadata and controls
37 lines (34 loc) · 1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
set nocount on
go
use USER_DATABASE_NAME
go
select 'use [' + db_name() + ']
go
'
SELECT/* roles.principal_id AS RolePrincipalID
, roles.name AS RolePrincipalName
, database_role_members.member_principal_id AS MemberPrincipalID
, members.name AS MemberPrincipalName
,*/
--roles.*
--,
-- Step 1: recreate users in database
'drop USER [' + members.name + ']
GO
CREATE USER [' + members.name + '] FOR LOGIN [' + members.name + ']
GO
'
/*
-- Step 2: add roles to users
'ALTER ROLE [' + roles.name + '] ADD MEMBER [' + members.name + '];
go
'
*/
FROM sys.database_role_members AS database_role_members
JOIN sys.database_principals AS roles ON database_role_members.role_principal_id = roles.principal_id
JOIN sys.database_principals AS members ON database_role_members.member_principal_id = members.principal_id
where members.name not in ('dbo')
--and roles.name like 'db[_]%'
order by members.name
;
GO