-
Notifications
You must be signed in to change notification settings - Fork 2
/
Find Object By Name.snippet
47 lines (45 loc) · 1.84 KB
/
Find Object By Name.snippet
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
<?xml version="1.0" encoding="utf-8" ?>
<CodeSnippets xmlns="http://schemas.microsoft.com/VisualStudio/2005/CodeSnippet">
<_locDefinition xmlns="urn:locstudio">
<_locDefault _loc="locNone" />
<_locTag _loc="locData">Title</_locTag>
<_locTag _loc="locData">Description</_locTag>
<_locTag _loc="locData">Author</_locTag>
<_locTag _loc="locData">ToolTip</_locTag>
</_locDefinition>
<CodeSnippet Format="1.0.0">
<Header>
<Title>Find Object By Name</Title>
<Shortcut></Shortcut>
<Description>Generates a script that searches for a SQL Server object by name across all databases (stored proc, view, function, etc.)</Description>
<Author>Dave Mason https://mastodon.social/@DaveMasonDotMe </Author>
<SnippetTypes>
<SnippetType>Expansion</SnippetType>
</SnippetTypes>
</Header>
<Snippet>
<Declarations>
<Literal>
<ID>ObjectName</ID>
<ToolTip>Name of the object (stored proc, view, function, etc.)</ToolTip>
<Default>ObjectName</Default>
</Literal>
</Declarations>
<Code Language="SQL">
<![CDATA[DECLARE @Tsql NVARCHAR(MAX) = '';
SELECT @Tsql = @Tsql + 'SELECT ''' + d.name + ''' AS DBName,
SCHEMA_NAME(o.schema_id) COLLATE SQL_Latin1_General_CP1_CI_AS AS SchemaName,
o.name COLLATE SQL_Latin1_General_CP1_CI_AS AS ObjectName,
o.type_desc COLLATE SQL_Latin1_General_CP1_CI_AS AS ObjectType
FROM [' + d.name + '].sys.objects o
WHERE o.name COLLATE SQL_Latin1_General_CP1_CI_AS = ''$ObjectName$'' UNION ALL ' + CHAR(13) + CHAR(10)
FROM master.sys.databases d
WHERE d.state_desc = 'ONLINE'
ORDER BY d.name
SELECT @Tsql = LEFT (@Tsql, LEN(@Tsql) - LEN('UNION ALL ' + CHAR(13) + CHAR(10)))
EXEC(@Tsql);
GO]]>
</Code>
</Snippet>
</CodeSnippet>
</CodeSnippets>