Sql server 设置@t=@w 设置@w='' 结束 打印“T=”+@T 设置@p=charindex(“”,@t) 如果@p=0 打印'NameError:'+@t+'->'+cast(@p作为varchar) 设置@name=SUBSTRING(@t,1,@p-1) 设置@t=子字符串(@t,@p+11000) 设置@p=CHARINDEX('=',@t) 如果@p>0开始 设置@default=Replace(LTrim(RTrim(子字符串(@t,@p+11000)),“”,“”) 设置@t=子字符串(@t,1,@p-1) 结束 设置@p=CHARINDEX('(',@t) 如果@p>0 设置@type=LTrim(RTrim(子字符串(@t,1,@p-1))) 其他的 设置@type=LTrim(RTrim(@t)) 插入@par(ParameterName、ParameterType、DefaultValue) 值(@name、@type、@default) 结束--而len(@w)>0 从c取下一个到@w 结束 关闭c 解除分配c 挑选* 来自@par
获取SP和函数的所有输入和输出参数集有更简单、更正确的方法,请尝试以下语句。 (来源为)Sql server 设置@t=@w 设置@w='' 结束 打印“T=”+@T 设置@p=charindex(“”,@t) 如果@p=0 打印'NameError:'+@t+'->'+cast(@p作为varchar) 设置@name=SUBSTRING(@t,1,@p-1) 设置@t=子字符串(@t,@p+11000) 设置@p=CHARINDEX('=',@t) 如果@p>0开始 设置@default=Replace(LTrim(RTrim(子字符串(@t,@p+11000)),“”,“”) 设置@t=子字符串(@t,1,@p-1) 结束 设置@p=CHARINDEX('(',@t) 如果@p>0 设置@type=LTrim(RTrim(子字符串(@t,1,@p-1))) 其他的 设置@type=LTrim(RTrim(@t)) 插入@par(ParameterName、ParameterType、DefaultValue) 值(@name、@type、@default) 结束--而len(@w)>0 从c取下一个到@w 结束 关闭c 解除分配c 挑选* 来自@par,sql-server,tsql,stored-procedures,sql-server-2012,Sql Server,Tsql,Stored Procedures,Sql Server 2012,获取SP和函数的所有输入和输出参数集有更简单、更正确的方法,请尝试以下语句。 (来源为) 选择SCHEMA\u NAME(SCHEMA\u ID)作为[SCHEMA], SO.Name作为[ObjectName], SO.Type_Desc AS[对象类型(UDF/SP)], PM.Parameter_ID为[ParameterID], 案例 当pm.system\u type\u id=pm.user\u type\u id时,则为“system\u type” else“用户类型” 结束为[
选择SCHEMA\u NAME(SCHEMA\u ID)作为[SCHEMA],
SO.Name作为[ObjectName],
SO.Type_Desc AS[对象类型(UDF/SP)],
PM.Parameter_ID为[ParameterID],
案例
当pm.system\u type\u id=pm.user\u type\u id时,则为“system\u type”
else“用户类型”
结束为[TypeDescr],
案例
当PM.Parameter_ID=0时,则“返回”
我叫什么名字
结束为[ParameterName],
“['+TYPE_NAME(PM.User_TYPE_ID)+']”作为[ParameterDataType],
案例
当在('float','uniqueidentifier','datetime','bit','bigint','int','image','money','xml','varbinary','tinyint','text','ntext','smallint','smallmoney')中键入\u NAME(PM.User\u TYPE \u ID)时,则
当在('decimal','numeric')中键入_NAME(PM.User_TYPE_ID)时,则“('+CAST(精度为VARCHAR(4))+”,'+CAST(比例为VARCHAR(4))+”)”
其他的
案例
当PM.Max_Length为-1时,则“('+CAST(PM.Max_Length为VARCHAR(4))+”)”
当(TYPE_NAME(PM.User_TYPE_ID)=“xml”)或(PM.system_TYPE_ID PM.User_TYPE_ID)时,则“”
else'(最大值)'
结束
结束为[大小],
案例
当PM.Is_Output=1时,则为“Output”
其他“输入”
结束为[方向]
从sys.objects开始
内部连接sys.parameters作为SO.OBJECT\u ID=PM.OBJECT\u ID上的PM
其中输入('P','FN')
ORDER BY[Schema],SO.Name,PM.parameter\u id
请按照此链接中的建议尝试sp_procedure_params_行集-感谢您的快速响应。毫无疑问,sp_procedure_params_行集“TestDefaultSpValue_Default”sp_procedure_params_行集“TestDefaultSpValue_NoDefault”返回相同的列和值。如此链接中所述,SQL Server仅维护CLR对象的默认值在此目录视图中;因此,对于Transact-SQL对象,此列的值为0。若要查看Transact-SQL对象中参数的默认值,请查询sys.SQL_modules目录视图的definition列,或使用object_definition system函数。我认为除了解析definition列之外,没有其他方法。请投票赞成更改e here:失败,因为您可以使用与以前一样的数据类型定义。您应该尝试:选择*from information_schema.information_schema.PARAMETERS,其中specific_name='my_sp_name'**您需要将MyProcName更改为proc的名称或通配符)**这将获得默认值,如果您喜欢CTE,则更容易理解(通用表表达式)
select *
from sys.objects so join sys.parameters sp on so.object_id = sp.object_id
where so.type='P'
and so.name = 'someSp'
exec sp_sproc_columns 'someSp'
CREATE PROCEDURE TestDefaultSpValue_Default
@I INT = 2
AS
BEGIN
SET NOCOUNT ON;
SELECT @I
END
CREATE PROCEDURE TestDefaultSpValue_NoDefault
@I INT
AS
BEGIN
SET NOCOUNT ON;
SELECT @I
END
ALTER PROCEDURE dbo.usp_test1
(
@a UNIQUEIDENTIFIER = NULL,
@b DATETIME = '20100101',
@c DATETIME = DEFAULT,
@d BIT = 1,
@e BIT,
@k INT = 1,
@f BIT = 0, @g NVARCHAR(MAX) = '23235',
@h INT = 3,
@j DECIMAL(10,2) = DEFAULT
)
WITH RECOMPILE
AS
BEGIN
PRINT 1;
END
SELECT
data3.name
, [default_value] = REVERSE(RTRIM(SUBSTRING(
data3.rtoken
, CASE
WHEN CHARINDEX(N',', data3.rtoken) > 0
THEN CHARINDEX(N',', data3.rtoken) + 1
WHEN CHARINDEX(N')', data3.rtoken) > 0
THEN CHARINDEX(N')', data3.rtoken) + 1
ELSE 1
END
, LEN(data3.rtoken)
)))
FROM (
SELECT
data2.name
, rtoken = REVERSE(
SUBSTRING(ptoken
, CHARINDEX('=', ptoken, 1) + 1
, LEN(data2.ptoken))
)
FROM (
SELECT
data.name
, ptoken = SUBSTRING(
data.tokens
, token_pos + name_length + 1
, ISNULL(ABS(next_token_pos - token_pos - name_length - 1), LEN(data.tokens))
)
FROM (
SELECT
sm3.tokens
, p.name
, name_length = LEN(p.name)
, token_pos = CHARINDEX(p.name, sm3.tokens)
, next_token_pos = CHARINDEX(p2.name, sm3.tokens)
FROM (
SELECT
sm2.[object_id]
, sm2.[type]
, tokens = REVERSE(SUBSTRING(sm2.tokens, ISNULL(CHARINDEX('SA', sm2.tokens) + 2, 0), LEN(sm2.tokens)))
FROM (
SELECT
sm.[object_id]
, o.[type]
, tokens = REVERSE(SUBSTRING(
sm.[definition]
, CHARINDEX(o.name, sm.[definition]) + LEN(o.name) + 1
, ABS(CHARINDEX(N'AS', sm.[definition]))
)
)
FROM sys.sql_modules sm WITH (NOLOCK)
JOIN sys.objects o WITH (NOLOCK) ON sm.[object_id] = o.[object_id]
JOIN sys.schemas s WITH (NOLOCK) ON o.[schema_id] = s.[schema_id]
WHERE o.[type] = 'P '
AND s.name + '.' + o.name = 'dbo.usp_test1'
) sm2
WHERE sm2.tokens LIKE '%=%'
) sm3
JOIN sys.parameters p WITH (NOLOCK) ON sm3.[object_id] = p.[object_id]
OUTER APPLY (
SELECT p2.name
FROM sys.parameters p2 WITH (NOLOCK)
WHERE p2.is_output = 0
AND sm3.[object_id] = p2.[object_id]
AND p.parameter_id + 1 = p2.parameter_id
) p2
WHERE p.is_output = 0
) data
) data2
WHERE data2.ptoken LIKE '%=%'
) data3
DECLARE @name SYSNAME = 'dbo.usp_test1'
IF EXISTS(
SELECT 1
FROM (
SELECT
sm2.[object_id]
, tokens = SUBSTRING(sm2.tokens, ISNULL(CHARINDEX('SA', sm2.tokens) + 2, 0), LEN(sm2.tokens))
FROM (
SELECT
sm.[object_id]
, tokens = REVERSE(SUBSTRING(
sm.[definition]
, CHARINDEX(o.name, sm.[definition]) + LEN(o.name) + 1
, ABS(CHARINDEX(N'AS', sm.[definition]))
)
)
FROM sys.sql_modules sm WITH (NOLOCK)
JOIN sys.objects o WITH (NOLOCK) ON sm.[object_id] = o.[object_id]
JOIN sys.schemas s WITH (NOLOCK) ON o.[schema_id] = s.[schema_id]
WHERE o.[type] = 'P '
AND s.name + '.' + o.name = @name
) sm2
) sm3
WHERE sm3.tokens LIKE '%=%'
) PRINT @name + ' have default values'
create procedure ViewParameters
@procedure varchar(50)
as
declare
@w varchar(max),
@p int, @p2 int,
@t varchar(max)
/* Andrey Rubanko 18 jul 2013 */
/* fill temporary table with procedure body */
select @w = definition
from sys.sql_modules
where object_id = object_id(@procedure)
declare @lines table (line varchar(500), id int identity(1, 1))
while len(@w) > 0 begin
set @p = charindex(char(10), @w)
if @p > 0 begin
insert @lines(line) values(replace(replace(SUBSTRING(@w, 1, @p - 1), char(13), ''), char(9), ' '))
set @w = SUBSTRING(@w, @p + 1, 10000)
end else begin
insert @lines(line) values(replace(@w, char(13), ''))
set @w = ''
end
end
/* remove comments */
declare
@i int,
@inCommentNow bit,
@again bit
set @i = 1
set @inCommentNow = 0
while @i <= (select max(id) from @lines) begin
select @w = line from @lines where id = @i
set @again = 0
if @inCommentNow = 0 begin
set @p = patindex('%--%', @w)
if @p > 0 begin
set @w = SUBSTRING(@w, 1, @p - 1)
update @lines
set line = @w
where id = @i
end
set @p = patIndex('%/*%', @w)
if @p > 0 begin
set @p2 = PATINDEX('%*/%', @w)
if @p2 > 0 begin
update @lines
set line = substring(@w, 1, @p - 1) + SUBSTRING(@w, @p2 + 2, 10000)
where id = @i
set @again = 1
end else begin
set @inCommentNow = 1
update @lines
set line = SUBSTRING(@w, 1, @p - 1)
where id = @i
end
end
end
if @inCommentNow = 1 begin
set @p = PATINDEX('%*/%', @w)
if @p > 0 begin
update @lines
set line = SUBSTRING(@w, @p + 2, 10000)
where id = @i
set @inCommentNow = 0
set @again = 1
end else
update @lines
set line = ''
where id = @i
end
if @again = 0
set @i = @i + 1
end
/* remove all except parameters */
declare
@first int,
@last int
set @i = 1
while @last is null begin
select @w = line from @lines where id = @i
if SUBSTRING(@w, 1, 2) = 'as'
set @last = @i - 1
set @p = PATINDEX('% as%', @w)
if @last is null and @p > 0 begin
set @w = SUBSTRING(@w, 1, @p - 1)
update @lines
set line = @w
where id = @i
if charindex('@', @w) > 0
set @last = @i
else
set @last = @i - 1
end
set @p = CHARINDEX('@', @w)
if @first is null and @p > 0 begin
set @first = @i
set @w = SUBSTRING(@w, @p, 10000)
end
set @i = @i + 1
end
delete @lines
where @first is null
or id < @first
or id > @last
/* decode lines to paramters */
declare @par table (ParameterName varchar(50), ParameterType varchar(50), DefaultValue varchar(50))
declare
@name varchar(50),
@type varchar(50),
@default varchar(50)
declare c cursor for
select line
from @lines
open c
fetch next from c into @w
while @@FETCH_STATUS = 0 begin
while len(@w) > 0 begin
set @default = null
set @w = SUBSTRING(@w, charindex('@', @w) + 1, 10000)
set @p = CHARINDEX(',', @w)
print 'start:' + @w
if @p > 0 begin
set @t = SUBSTRING(@w, 1, @p - 1)
set @w = LTrim(RTrim(SUBSTRING(@w, @p + 1, 10000)))
end else begin
set @p = patindex('% as%', @w)
if @p > 0
set @t = SUBSTRING(@w, 1, @p - 1)
else
set @t = @w
set @w = ''
end
print 'T=' + @t
set @p = charindex(' ', @t)
if @p = 0
print 'NameError:' + @t + ' ->' + cast(@p as varchar)
set @name = SUBSTRING(@t, 1, @p - 1)
set @t = SUBSTRING(@t, @p + 1, 10000)
set @p = CHARINDEX('=', @t)
if @p > 0 begin
set @default = Replace(LTrim(RTrim(SUBSTRING(@t, @p + 1, 10000))), '''', '')
set @t = SUBSTRING(@t, 1, @p - 1)
end
set @p = CHARINDEX('(', @t)
if @p > 0
set @type = LTrim(RTrim(SUBSTRING(@t, 1, @p - 1)))
else
set @type = LTrim(RTrim(@t))
insert @par (ParameterName, ParameterType, DefaultValue)
values(@name, @type, @default)
end--while len(@w) > 0
fetch next from c into @w
end
close c
deallocate c
select *
from @par
SELECT SCHEMA_NAME(SCHEMA_ID) AS [Schema],
SO.Name AS [ObjectName],
SO.Type_Desc AS [ObjectType (UDF/SP)],
PM.Parameter_ID AS [ParameterID],
case
when pm.system_type_id = pm.user_type_id then 'system_type'
else 'user_type'
end as [TypeDescr],
CASE
WHEN PM.Parameter_ID = 0 THEN 'Returns'
ELSE PM.Name
END AS [ParameterName],
'['+TYPE_NAME(PM.User_Type_ID)+']' AS [ParameterDataType],
CASE
WHEN TYPE_NAME(PM.User_Type_ID) IN ('float', 'uniqueidentifier', 'datetime', 'bit', 'bigint', 'int', 'image', 'money', 'xml', 'varbinary', 'tinyint', 'text', 'ntext', 'smallint', 'smallmoney') THEN ''
WHEN TYPE_NAME(PM.User_Type_ID) IN ('decimal', 'numeric') THEN '(' + CAST( Precision AS VARCHAR(4) ) + ', ' + CAST( Scale AS VARCHAR(4)) + ')'
ELSE
case
when PM.Max_Length <> -1 then '('+CAST( PM.Max_Length AS VARCHAR(4))+')'
when (TYPE_NAME(PM.User_Type_ID) = 'xml') or (pm.system_type_id <> pm.user_type_id) then ''
else '(max)'
end
END AS [Size],
CASE
WHEN PM.Is_Output = 1 THEN 'Output'
ELSE 'Input'
END AS [Direction]
FROM sys.objects AS SO
INNER JOIN sys.parameters AS PM ON SO.OBJECT_ID = PM.OBJECT_ID
WHERE TYPE IN ('P','FN')
ORDER BY [Schema], SO.Name, PM.parameter_id
WITH t1 AS
(
SELECT
SCHEMA_NAME(SCHEMA_ID) AS [Schema]
,SO.name
, SO.type
,SO.Type_Desc AS [ObjectType (UDF/SP)]
,P.parameter_id AS [ParameterID]
,P.name AS [ParameterName]
,P.user_type_id
/*,P.scale
,P.precision
,P.max_length
*/
,TYPE_NAME(P.user_type_id) AS [ParameterDataType]
-- ,P.max_length AS [ParameterMaxBytes]
,CASE WHEN user_type_id = 231 THEN max_length / 2 ELSE NULL END nvarcharsize
,P.is_output AS [IsOutPutParameter]
,ltrim(rtrim(REPLACE(LEFT( OBJECT_DEFINITION (p.object_id),90000),'CREATE PROCEDURE ',''))) ProcDef
FROM sys.objects AS SO
INNER JOIN sys.parameters AS P ON SO.OBJECT_ID = P.OBJECT_ID AND SO.type = 'P'
AND SO.Name NOT LIKE 'Report%'
AND SO.Name NOT LIKE '!_%' ESCAPE '!'
)
, T2 AS
(
select
--ProcDef
LEFT(ProcDef,patindex('%AS%BEGIN%',ProcDef)-2) ProcedureDef
,
name Procname,
ParameterName,
ParameterID,
ParameterDataType,
nvarcharsize
from t1
)
, T3 AS
(
select
substring(ProcedureDef,charindex(ParameterName,ProcedureDef) + len(parametername) + len(ParameterDataType) + 2,12) parampos
,
* from t2 where procname like 'MyProcName'
)
, T4 AS
(
select
CHARINDEX('=',parampos) haseq,
replace(replace(replace(substring(parampos,CHARINDEX('=',parampos),100),' ',''),'=',''),',','') valdef
,
* from t3
)
, t5 as
(
select
CASE WHEN haseq > 0 THEN valdef else '' end defaultvalue,
* from t4
)
select * from t5
ORDER BY Procname, parameterid
GO