forked from BrentOzarULTD/SQL-Server-First-Responder-Kit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUninstall.sql
81 lines (57 loc) · 2.2 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
--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_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;
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;
FETCH NEXT FROM c INTO @dbname;
END
CLOSE c;
DEALLOCATE c;
END
IF OBJECT_ID('dbo.SqlServerVersions') IS NOT NULL
DROP TABLE dbo.SqlServerVersions;
PRINT @SQL;
IF(@printOnly = 0)
EXEC sp_executesql @SQL