-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathFind-DbIndexes.ps1
80 lines (69 loc) · 2.7 KB
/
Find-DbIndexes.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
<#
.SYNOPSIS
Returns indexes using a column with the given name.
.OUTPUTS
System.Management.Automation.PSCustomObject with these properties:
* SchemaName
* TableName
* IndexName
* IndexOrdinal
* IsUnique
* IsClustered
* IsDisabled
* ColumnsInIndex
.FUNCTIONALITY
Database
.LINK
Invoke-Sqlcmd
.LINK
ConvertFrom-DataRow.ps1
.LINK
https://docs.microsoft.com/sql/relational-databases/system-catalog-views/sys-index-columns-transact-sql
.EXAMPLE
Find-DbIndexes.ps1 -ServerInstance '(localdb)\ProjectsV13' -Database AdventureWorks2014 -ColumnName ErrorLogID
SchemaName : dbo
TableName : ErrorLog
IndexName : PK_ErrorLog_ErrorLogID
IndexOrdinal : 1
IsUnique : 1
IsClustered : 1
IsDisabled : 0
ColumnsInIndex : 1
#>
#Requires -Version 3
#Requires -Module SqlServer
[CmdletBinding()][OutputType([Management.Automation.PSCustomObject])] Param(
<#
The name of a server (and optional instance) to connect and use for the query.
May be used with optional Database, Credential, and ConnectionProperties parameters.
#>
[Parameter(ParameterSetName='ByConnectionParameters',Position=0,Mandatory=$true)][string] $ServerInstance,
# The the database to connect to on the server.
[Parameter(ParameterSetName='ByConnectionParameters',Position=1,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,
# The column name to search for.
[Parameter(Position=2,Mandatory=$true)][Alias('ColName')][string]$ColumnName
)
Use-SqlcmdParams.ps1
Invoke-Sqlcmd @"
select object_schema_name(i.object_id) SchemaName,
object_name(i.object_id) TableName,
i.name IndexName,
ic.index_column_id IndexOrdinal,
indexproperty(i.object_id,i.name,'IsUnique') IsUnique,
indexproperty(i.object_id,i.name,'IsClustered') IsClustered,
indexproperty(i.object_id,i.name,'IsDisabled') IsDisabled,
(select count(*) from sys.index_columns c where c.object_id = i.object_id and c.index_id = i.index_id) ColumnsInIndex
from sys.index_columns ic
join sys.indexes i
on ic.object_id = i.object_id
and ic.index_id = i.index_id
where col_name(ic.object_id,ic.column_id) = '$($ColumnName -replace "'","''")'
order by TableName, IndexName;
"@ |ConvertFrom-DataRow.ps1