-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathprint_def.sql
More file actions
99 lines (84 loc) · 4.14 KB
/
print_def.sql
File metadata and controls
99 lines (84 loc) · 4.14 KB
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
exec dbo.drop_if_exists 'dbo.print_def'
GO
-- Outputs the definition of an object
create procedure [dbo].[print_def]
@name nvarchar(max)
as
set nocount on
declare
@object_id int = object_id(@name)
if @object_id is null
begin
raiserror('Object "%s" does not exist', 11, 1, @name)
return
end
declare
@object_name sysname = object_name(@object_id),
@object_schema_name sysname = object_schema_name(@object_id),
@object_definition nvarchar(max)
set @name = quotename(@object_schema_name) + '.' + quotename(@object_name)
if exists (select * from sys.sql_modules where object_id = @object_id)
set @object_definition = '
' + object_definition(@object_id)
else
if exists (select * from sys.tables where object_id = @object_id)
begin
declare @output nvarchar(max), @deferred_ddl nvarchar(max)
exec dbo.tbl_def @name, @output out, @deferred_ddl out
set @object_definition = @output + isnull('
GO' + nullif(ltrim(rtrim(@deferred_ddl)), ''), '')
end
declare @def nvarchar(max) = 'exec dbo.drop_if_exists ''' + @name + '''
GO' + ltrim(rtrim(@object_definition)) + '
GO'
declare
@level0type varchar(128),
@level0name sysname,
@level1type varchar(128),
@level1name sysname,
@level2type varchar(128),
@level2name sysname
exec dbo.ex_prop_params @name, @level0type out, @level0name out, @level1type out, @level1name out, @level2type out, @level2name out
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
null, null'
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, null, null)
if @level1type in ('function', 'table', 'view')
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
''column'', ' + quotename(objname, '''')
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, 'column', null)
if @level1type in ('function', 'table')
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
''constraint'', ' + quotename(objname, '''')
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, 'constraint', null)
if @level1type in ('table', 'view')
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
''index'', ' + quotename(objname, '''')
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, 'index', null)
if @level1type in ('function', 'procedure')
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
''parameter'', ' + quotename(objname, '''')
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, 'parameter', null)
if @level1type in ('table', 'view')
select @def += '
exec sp_addextendedproperty ' + quotename(name, '''') + ', ''' + replace(convert(nvarchar(max), value), '''', '''''') + ''',
' + quotename(@level0type, '''') + ', ' + quotename(@level0name, '''') + ',
' + quotename(@level1type, '''') + ', ' + quotename(@level1name, '''') + ',
''trigger'', ' + quotename(objname, '''')
from fn_listextendedproperty(null, @level0type, @level0name, @level1type, @level1name, 'trigger', null)
exec dbo.print_long @def
GO