-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathSSRS.Update_Subscription_Owner.sql
185 lines (165 loc) · 4.19 KB
/
SSRS.Update_Subscription_Owner.sql
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
/*------------------------------------------------------------------------------+
| Purpose: How to Update the owner of deployed reports and subscriptions
| Note: SQLCmdMode Script
+--------------------------------------------------------------------------------
:setvar _server "Server1"
:setvar _user "***username***"
:setvar _password "***password***"
:setvar _database "ReportServer"
:connect $(_server) -U $(_user) -P $(_password)
USE [$(_database)];
GO
*/
:SETVAR OldUser "DOMAIN\OldUserName"
:SETVAR NewUser "DOMAIN\NewUserName"
SET XACT_ABORT ON
BEGIN TRANSACTION
PRINT '====================================================================='
PRINT 'Find subscriptions for user...'
PRINT '====================================================================='
;WITH
user_list
AS
(
SELECT UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
--SELECT 'BEFORE', * FROM user_list
SELECT
'BEFORE'
, ul.UserName
, sb.*
FROM
dbo.Subscriptions sb
INNER JOIN user_list ul ON sb.OwnerID = ul.UserID
PRINT '====================================================================='
PRINT 'Update subscriptions...'
PRINT '====================================================================='
;WITH
user_old
AS
(
SELECT Old_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
,
user_new
AS
(
SELECT New_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(NewUser)'
)
--SELECT
-- uo.UserName
-- , un.UserName
UPDATE
dbo.Subscriptions
SET
OwnerID = un.New_UserID
FROM
dbo.Subscriptions sb
INNER JOIN user_old uo ON sb.OwnerID = uo.Old_UserID
, user_new un
PRINT '====================================================================='
PRINT 'Update reports...'
PRINT '====================================================================='
;WITH
user_old
AS
(
SELECT Old_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
,
user_new
AS
(
SELECT New_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(NewUser)'
)
UPDATE
dbo.Catalog
SET
CreatedById = un.New_UserID
FROM
dbo.Catalog AS c
INNER JOIN user_old uo ON c.CreatedById = uo.Old_UserID
, user_new un
--WHERE c.Type = 2
;WITH
user_old
AS
(
SELECT Old_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
,
user_new
AS
(
SELECT New_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(NewUser)'
)
UPDATE
dbo.Catalog
SET
ModifiedById = un.New_UserID
FROM
dbo.Catalog AS c
INNER JOIN user_old uo ON c.ModifiedById = uo.Old_UserID
, user_new un
--WHERE c.Type = 2
;WITH
user_old
AS
(
SELECT Old_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
,
user_new
AS
(
SELECT New_UserID = UserID, UserName FROM dbo.Users WHERE UserName = N'$(NewUser)'
)
SELECT
c.CreatedById
, c.ModifiedById
, uo.UserName
, un.UserName
, c.*
FROM
dbo.Catalog AS c
INNER JOIN user_old uo ON c.CreatedById = uo.Old_UserID
, user_new un
PRINT '====================================================================='
PRINT 'Find OLD subscriptions for user...'
PRINT '====================================================================='
;WITH
user_list
AS
(
SELECT UserID, UserName FROM dbo.Users WHERE UserName = N'$(OldUser)'
)
--SELECT 'BEFORE', * FROM user_list
SELECT
'AFTER'
, ul.UserName
, sb.*
FROM
dbo.Subscriptions sb
INNER JOIN user_list ul ON sb.OwnerID = ul.UserID
PRINT '====================================================================='
PRINT 'Find NEW subscriptions for user...'
PRINT '====================================================================='
;WITH
user_list
AS
(
SELECT UserID, UserName FROM dbo.Users WHERE UserName = N'$(NewUser)'
)
--SELECT 'BEFORE', * FROM user_list
SELECT
'AFTER'
, ul.UserName
, sb.*
FROM
dbo.Subscriptions sb
INNER JOIN user_list ul ON sb.OwnerID = ul.UserID
ROLLBACK TRANSACTION
--COMMIT TRANSACTION
PRINT '====================================================================='
PRINT 'Finished...'
PRINT '====================================================================='