/
Get-DbaDbSynonym.ps1
150 lines (111 loc) 路 5.72 KB
/
Get-DbaDbSynonym.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
147
148
149
150
function Get-DbaDbSynonym {
<#
.SYNOPSIS
Get the synonym(s) for database(s) / instance(s) of SQL Server.
.DESCRIPTION
The Get-DbaDbSynonym returns the synonym(s) for database(s) / instance(s) of SQL Server.
.PARAMETER SqlInstance
The target SQL Server instance or instances. This can be a collection and receive pipeline input to allow the function to be executed against multiple SQL Server 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 database(s) to process. This list is auto-populated from the server. If unspecified, all databases will be processed.
.PARAMETER ExcludeDatabase
The database(s) to exclude. This list is auto-populated from the server.
.PARAMETER Schema
The schema(s) to process. If unspecified, all schemas will be processed.
.PARAMETER ExcludeSchema
The schema(s) to exclude.
.PARAMETER Synonym
The synonym(s) to process. If unspecified, all synonyms will be processed.
.PARAMETER ExcludeSynonym
The synonym(s) to exclude.
.PARAMETER InputObject
Enables piped input from Get-DbaDatabase
.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.
.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: Database, Synonym
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/Get-DbaDbSynonym
.EXAMPLE
PS C:\> Get-DbaDbSynonym -SqlInstance localhost
Returns all database synonyms in all databases on the local default SQL Server instance
.EXAMPLE
PS C:\> Get-DbaDbSynonym -SqlInstance localhost, sql2016
Returns all synonyms of all database(s) on the local and sql2016 SQL Server instances
.EXAMPLE
PS C:\> $servers = Get-Content C:\servers.txt
PS C:\> $servers | Get-DbaDbSynonym
Returns synonyms of all database(s) for every server in C:\servers.txt
.EXAMPLE
PS C:\> Get-DbaDbSynonym -SqlInstance localhost -Database db1
Returns synonyms of the database db1 on localhost.
.EXAMPLE
PS C:\> Get-DbaDbSynonym -SqlInstance localhost -Database db1 -Synonym 'synonym1'
Returns the synonym1 synonym in the db1 database on localhost.
#>
[CmdletBinding(SupportsShouldProcess, ConfirmImpact = 'Low')]
param (
[parameter(ValueFromPipeline)]
[DbaInstance[]]$SqlInstance,
[PSCredential]$SqlCredential,
[string[]]$Database,
[string[]]$ExcludeDatabase,
[string[]]$Schema,
[string[]]$ExcludeSchema,
[string[]]$Synonym,
[string[]]$ExcludeSynonym,
[parameter(ValueFromPipeline)]
[Microsoft.SqlServer.Management.Smo.Database[]]$InputObject,
[switch]$EnableException
)
process {
if (-not $InputObject -and -not $SqlInstance) {
Stop-Function -Message "You must pipe in a database or specify a SqlInstance"
return
}
if ($SqlInstance) {
$InputObject += Get-DbaDatabase -SqlInstance $SqlInstance -SqlCredential $SqlCredential -Database $Database -ExcludeDatabase $ExcludeDatabase
}
foreach ($db in $InputObject) {
if ($db.IsAccessible -eq $false) {
continue
}
$server = $db.Parent
Write-Message -Level 'Verbose' -Message "Getting Database Synonyms for $db on $server"
$dbSynonyms = $db.Synonyms
if ($Synonym) {
$dbSynonyms = $dbSynonyms | Where-Object { $_.Name -in $Synonym }
}
if ($ExcludeSynonym) {
$dbSynonyms = $dbSynonyms | Where-Object { $_.Name -notin $ExcludeSynonym }
}
if ($Schema) {
$dbSynonyms = $dbSynonyms | Where-Object { $_.Schema -in $Schema }
}
if ($ExcludeSchema) {
$dbSynonyms = $dbSynonyms | Where-Object { $_.Schema -notin $ExcludeSchema }
}
foreach ($dbSynonym in $dbSynonyms) {
Add-Member -Force -InputObject $dbSynonym -MemberType NoteProperty -Name ComputerName -Value $server.ComputerName
Add-Member -Force -InputObject $dbSynonym -MemberType NoteProperty -Name InstanceName -Value $server.ServiceName
Add-Member -Force -InputObject $dbSynonym -MemberType NoteProperty -Name SqlInstance -Value $server.DomainInstanceName
Add-Member -Force -InputObject $dbSynonym -MemberType NoteProperty -Name Database -Value $db.Name
Select-DefaultView -InputObject $dbSynonym -Property "ComputerName", "InstanceName", "SqlInstance", "Database", "Schema", "Name", "BaseServer", "BaseDatabase", "BaseSchema", "BaseObject"
}
}
}
}