-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathFind-DbColumn.ps1
153 lines (137 loc) · 5.67 KB
/
Find-DbColumn.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
151
152
153
<#
.SYNOPSIS
Searches for database columns.
.OUTPUTS
System.Management.Automation.PSCustomObject for each found column:
* TableSchema
* TableName
* ColumnName
* DataType
* Nullable
* DefaultValue
.FUNCTIONALITY
Database
.COMPONENT
System.Configuration
.LINK
ConvertFrom-DataRow.ps1
.LINK
Stop-ThrowError.ps1
.LINK
Invoke-Sqlcmd
.EXAMPLE
Find-DbColumn.ps1 -ServerInstance '(localdb)\ProjectsV13' -Database AdventureWorks2016 -IncludeColumns %price% |Format-Table -AutoSize
TableSchema TableName ColumnName DataType Nullable DefaultValue
----------- --------- ---------- -------- -------- ------------
Production Product ListPrice money False
Production ProductListPriceHistory ListPrice money False
Purchasing ProductVendor StandardPrice money False
Purchasing PurchaseOrderDetail UnitPrice money False
Sales SalesOrderDetail UnitPrice money False
Sales SalesOrderDetail UnitPriceDiscount money False ((0.0))
#>
#Requires -Version 3
[CmdletBinding()][OutputType([Management.Automation.PSCustomObject])] Param(
# The server and instance to connect to.
[Parameter(ParameterSetName='ByConnectionParameters',Mandatory=$true)][string] $ServerInstance,
# The database to use.
[Parameter(ParameterSetName='ByConnectionParameters',Mandatory=$true)][string] $Database,
# Specifies a connection string to connect to the server.
[Parameter(ParameterSetName='ByConnectionString',Mandatory=$true)][Alias('ConnStr','CS')][string] $ConnectionString,
# Specifies an SMO Database object to query.
[Parameter(ParameterSetName='ByDatabase',Mandatory=$true)]
[Microsoft.SqlServer.Management.Smo.Database] $SmoDatabase,
# The connection string name from the ConfigurationManager to use.
[Parameter(ParameterSetName='ByConnectionName',Mandatory=$true)][string] $ConnectionName,
# A like-pattern of database schemata to include (will only include these).
[string[]] $IncludeSchemata,
# A like-pattern of database schemata to exclude.
[string[]] $ExcludeSchemata,
# A like-pattern of database tables to include (will only include these).
[string[]] $IncludeTables,
# A like-pattern of database tables to exclude.
[string[]] $ExcludeTables,
# A like-pattern of database columns to include (will only include these).
[string[]] $IncludeColumns,
# A like-pattern of database columns to exclude.
[string[]] $ExcludeColumns,
# The basic datatype to search for.
[ValidateSet('char','byte','int','long','decimal','double','date','datetime','time')]
[string] $DataType,
# The minimum character column length.
[int] $MinLength,
# The maximum character column length.
[int] $MaxLength
)
try{[void][Configuration.ConfigurationManager]}catch{Add-Type -AssemblyName System.Configuration}
function Format-LikeCondition([string]$column,[string[]]$patterns,[switch]$not)
{
$like,$andOr = if($not){'not like','and'}else{'like','or'}
@"
and ( $(($patterns |ForEach-Object {"$column $like '$($_ -replace '''','''''')' escape '\'"}) -join " $andOr ") )
"@
}
Use-SqlcmdParams.ps1 -QueryTimeout 300
$colssql = @"
select TABLE_SCHEMA TableSchema,
TABLE_NAME TableName,
COLUMN_NAME ColumnName,
DATA_TYPE +
case
when DATA_TYPE in ('int','smallint','bigint','tinyint','money','bit') then ''
when CHARACTER_MAXIMUM_LENGTH is not null then '(' + cast(CHARACTER_MAXIMUM_LENGTH as varchar) + ')'
when NUMERIC_PRECISION is not null then '(' + cast(NUMERIC_PRECISION as varchar) +
case when NUMERIC_PRECISION_RADIX is not null and NUMERIC_PRECISION_RADIX <> 10 then ' base ' +
cast(NUMERIC_PRECISION_RADIX as varchar) else '' end +
case when NUMERIC_SCALE is not null then ',' + cast(NUMERIC_SCALE as varchar) else '' end + ')'
else ''
end DataType,
cast(case IS_NULLABLE when 'Yes' then 1 else 0 end as bit) Nullable,
COLUMN_DEFAULT DefaultValue
from INFORMATION_SCHEMA.COLUMNS
"@
$colssql += switch($DataType)
{
string {@"
where DATA_TYPE in ('varchar','char','nvarchar','nchar')
$(if($MinLength){" and (CHARACTER_MAXIMUM_LENGTH = -1 or CHARACTER_MAXIMUM_LENGTH >= $MinLength)"})
$(if($MaxLength){" and (CHARACTER_MAXIMUM_LENGTH = -1 or CHARACTER_MAXIMUM_LENGTH >= $MaxLength)"})
"@}
byte {@"
where DATA_TYPE in ('tinyint')
"@}
int {@"
where DATA_TYPE in ('int')
"@}
long {@"
where (DATA_TYPE = 'bigint'
or (DATA_TYPE in ('numeric','decimal') and NUMERIC_SCALE = 0))
"@}
decimal {@"
where DATA_TYPE in ('money','smallmoney')
"@}
{$_ -in 'float','double'} {@"
where DATA_TYPE in ('float','real','numeric','decimal')
"@}
date {@"
where DATA_TYPE in ('date','datetime','datetime2','datetimeoffset','smalldatetime')
"@}
datetime {@"
where DATA_TYPE in ('datetime','datetime2','datetimeoffset','smalldatetime')
"@}
time {@"
where DATA_TYPE in ('time')
"@}
default {@"
where 1 = 1
"@}
}
if($IncludeSchemata) { $colssql += Format-LikeCondition TABLE_SCHEMA $IncludeSchemata }
if($ExcludeSchemata) { $colssql += Format-LikeCondition TABLE_SCHEMA $ExcludeSchemata -Not }
if($IncludeTables) { $colssql += Format-LikeCondition TABLE_NAME $IncludeTables }
if($ExcludeTables) { $colssql += Format-LikeCondition TABLE_NAME $ExcludeTables -Not }
if($IncludeColumns) { $colssql += Format-LikeCondition COLUMN_NAME $IncludeColumns }
if($ExcludeColumns) { $colssql += Format-LikeCondition COLUMN_NAME $ExcludeColumns -Not }
$colssql += ' order by TABLE_SCHEMA, TABLE_NAME, ORDINAL_POSITION;'
Write-Debug "Schema Query:`n$colssql"
Invoke-Sqlcmd $colssql |ConvertFrom-DataRow.ps1