-
-
Notifications
You must be signed in to change notification settings - Fork 794
/
Remove-DbaDbUdf.ps1
146 lines (120 loc) · 5.95 KB
/
Remove-DbaDbUdf.ps1
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
function Remove-DbaDbUdf {
<#
.SYNOPSIS
Removes a database user defined function(s) from each database and SQL Server instance.
.DESCRIPTION
Removes a database user defined function(s), with supported piping from Get-DbaDbUdf.
.PARAMETER SqlInstance
The target SQL Server instance or instances.
.PARAMETER SqlCredential
Login to the target instance using alternative credentials. Accepts PowerShell credentials (Get-Credential).
Windows Authentication, SQL Server Authentication, Active Directory - Password, and Active Directory - Integrated are all supported.
For MFA support, please use Connect-DbaInstance.
.PARAMETER Database
The target database(s).
.PARAMETER ExcludeDatabase
The database(s) to exclude - this list is auto populated from the server.
.PARAMETER ExcludeSystemUdf
This switch removes all system objects from the UDF collection.
.PARAMETER Schema
The schema(s) to process. If unspecified, all schemas will be processed.
.PARAMETER ExcludeSchema
The schema(s) to exclude.
.PARAMETER Name
The name(s) of the user defined functions to process. If unspecified, all user defined functions will be processed.
.PARAMETER ExcludeName
The name(s) of the user defined functions to exclude.
.PARAMETER InputObject
Allows piping from Get-DbaDbUdf.
.PARAMETER WhatIf
Shows what would happen if the command were to run. No actions are actually performed.
.PARAMETER Confirm
Prompts you for confirmation before executing any changing operations within the command.
This is the default. Use -Confirm:$false to suppress these prompts.
.PARAMETER EnableException
By default, when something goes wrong we try to catch it, interpret it and give you a friendly warning message.
This avoids overwhelming you with "sea of red" exceptions, but is inconvenient because it basically disables advanced scripting.
Using this switch turns this "nice by default" feature off and enables you to catch exceptions with your own try/catch.
.NOTES
Tags: Udf, Database
Author: Mikey Bronowski (@MikeyBronowski), bronowski.it
Website: https://dbatools.io
Copyright: (c) 2021 by dbatools, licensed under MIT
License: MIT https://opensource.org/licenses/MIT
.LINK
https://dbatools.io/Remove-DbaDbUdf
.EXAMPLE
PS C:\> Remove-DbaDbUdf -SqlInstance localhost, sql2016 -Database db1, db2 -Name udf1, udf2, udf3
Removes udf1, udf2, udf3 from db1 and db2 on the local and sql2016 SQL Server instances.
.EXAMPLE
PS C:\> $udfs = Get-DbaDbUdf -SqlInstance localhost, sql2016 -Database db1, db2 -Name udf1, udf2, udf3
PS C:\> $udfs | Remove-DbaDbUdf
Removes udf1, udf2, udf3 from db1 and db2 on the local and sql2016 SQL Server instances.
#>
[CmdletBinding(SupportsShouldProcess, ConfirmImpact = 'High')]
param (
[Parameter(ParameterSetName = 'NonPipeline', Mandatory = $true, Position = 0)]
[DbaInstanceParameter[]]$SqlInstance,
[Parameter(ParameterSetName = 'NonPipeline')]
[PSCredential]$SqlCredential,
[Parameter(ParameterSetName = 'NonPipeline')]
[string[]]$Database,
[Parameter(ParameterSetName = 'NonPipeline')]
[object[]]$ExcludeDatabase,
[Parameter(ParameterSetName = 'NonPipeline')]
[switch]$ExcludeSystemUdf,
[Parameter(ParameterSetName = 'NonPipeline')]
[string[]]$Schema,
[Parameter(ParameterSetName = 'NonPipeline')]
[string[]]$ExcludeSchema,
[Parameter(ParameterSetName = 'NonPipeline')]
[string[]]$Name,
[Parameter(ParameterSetName = 'NonPipeline')]
[string[]]$ExcludeName,
[parameter(ValueFromPipeline, ParameterSetName = 'Pipeline', Mandatory = $true)]
[Microsoft.SqlServer.Management.Smo.UserDefinedFunction[]]$InputObject,
[Parameter(ParameterSetName = 'NonPipeline')][Parameter(ParameterSetName = 'Pipeline')]
[switch]$EnableException
)
begin {
$udfs = @( )
}
process {
if ($SqlInstance) {
$params = $PSBoundParameters
$null = $params.Remove('WhatIf')
$null = $params.Remove('Confirm')
$udfs = Get-DbaDbUdf @params
} else {
$udfs += $InputObject
}
}
end {
# We have to delete in the end block to prevent "Collection was modified; enumeration operation may not execute." if directly piped from Get-DbaDbUdf.
foreach ($udfItem in $udfs) {
if ($PSCmdlet.ShouldProcess($udfItem.Parent.Parent.Name, "Removing the user defined function $($udfItem.Schema).$($udfItem.Name) in the database $($udfItem.Parent.Name) on $($udfItem.Parent.Parent.Name)")) {
$output = [PSCustomObject]@{
ComputerName = $udfItem.Parent.Parent.ComputerName
InstanceName = $udfItem.Parent.Parent.ServiceName
SqlInstance = $udfItem.Parent.Parent.DomainInstanceName
Database = $udfItem.Parent.Name
Udf = "$($udfItem.Schema).$($udfItem.Name)"
UdfName = $udfItem.Name
UdfSchema = $udfItem.Schema
Status = $null
IsRemoved = $false
}
try {
$udfItem.Drop()
$output.Status = "Dropped"
$output.IsRemoved = $true
} catch {
Stop-Function -Message "Failed removing the user defined function $($udfItem.Schema).$($udfItem.Name) in the database $($udfItem.Parent.Name) on $($udfItem.Parent.Parent.Name)" -ErrorRecord $_
$output.Status = (Get-ErrorMessage -Record $_)
$output.IsRemoved = $false
}
$output
}
}
}
}