-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Uninstall.sql
89 lines (63 loc) · 2.65 KB
/
Uninstall.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
--First Responder Kit Uninstaller Script
--Configuration Parameters
DECLARE @allDatabases bit = 0; --Flip this bit to 1 if you want to uninstall the scripts from all the databases, not only the current one
DECLARE @printOnly bit = 0; --Flip this bit to 1 if you want to print the drop commands only without executing
--End Configuration
--Variables
SET NOCOUNT ON;
DECLARE @SQL nvarchar(max) = N'';
IF OBJECT_ID('tempdb.dbo.#ToDelete') IS NOT NULL
DROP TABLE #ToDelete;
SELECT 'sp_AllNightLog' as ProcedureName INTO #ToDelete UNION
SELECT 'sp_AllNightLog_Setup' as ProcedureName UNION
SELECT 'sp_Blitz' as ProcedureName UNION
SELECT 'sp_BlitzAnalysis' as ProcedureName UNION
SELECT 'sp_BlitzBackups' as ProcedureName UNION
SELECT 'sp_BlitzCache' as ProcedureName UNION
SELECT 'sp_BlitzFirst' as ProcedureName UNION
SELECT 'sp_BlitzInMemoryOLTP' as ProcedureName UNION
SELECT 'sp_BlitzIndex' as ProcedureName UNION
SELECT 'sp_BlitzLock' as ProcedureName UNION
SELECT 'sp_BlitzQueryStore' as ProcedureName UNION
SELECT 'sp_BlitzWho' as ProcedureName UNION
SELECT 'sp_DatabaseRestore' as ProcedureName UNION
SELECT 'sp_foreachdb' as ProcedureName UNION
SELECT 'sp_ineachdb' as ProcedureName
--End Variables
IF (@allDatabases = 0)
BEGIN
SELECT @SQL += N'DROP PROCEDURE dbo.' + D.ProcedureName + ';' + CHAR(10)
FROM sys.procedures P
JOIN #ToDelete D ON D.ProcedureName = P.name COLLATE DATABASE_DEFAULT;
SELECT @SQL += N'DROP TABLE dbo.SqlServerVersions;' + CHAR(10)
FROM sys.tables
WHERE schema_id = 1 AND name = 'SqlServerVersions';
END
ELSE
BEGIN
DECLARE @dbname SYSNAME;
DECLARE @innerSQL NVARCHAR(max);
DECLARE c CURSOR LOCAL FAST_FORWARD
FOR SELECT QUOTENAME([name])
FROM sys.databases
WHERE [state] = 0;
OPEN c;
FETCH NEXT FROM c INTO @dbname;
WHILE(@@FETCH_STATUS = 0)
BEGIN
SET @innerSQL = N' SELECT @SQL += N''USE ' + @dbname + N';' + NCHAR(10) + N'DROP PROCEDURE dbo.'' + D.ProcedureName + '';'' + NCHAR(10)
FROM ' + @dbname + N'.sys.procedures P
JOIN #ToDelete D ON D.ProcedureName = P.name COLLATE DATABASE_DEFAULT';
EXEC sp_executesql @innerSQL, N'@SQL nvarchar(max) OUTPUT', @SQL = @SQL OUTPUT;
SET @innerSQL = N' SELECT @SQL += N''USE ' + @dbname + N';' + NCHAR(10) + N'DROP TABLE dbo.SqlServerVersions;'' + NCHAR(10)
FROM ' + @dbname + N'.sys.tables
WHERE schema_id = 1 AND name = ''SqlServerVersions''';
EXEC sp_executesql @innerSQL, N'@SQL nvarchar(max) OUTPUT', @SQL = @SQL OUTPUT;
FETCH NEXT FROM c INTO @dbname;
END
CLOSE c;
DEALLOCATE c;
END
PRINT @SQL;
IF(@printOnly = 0)
EXEC sp_executesql @SQL