SQL Server 2005元数据搜索以获取存储过程参数

发布于 2024-09-15 03:46:18 字数 65 浏览 3 评论 0原文

如何在 SQL Server 2005 中使用元数据获取存储过程的输入参数列表?我想对其进行选择,然后迭代变量名称。

How do you get a list of the input parameters for a stored procedure using metadata in SQL Server 2005? I want to do a SELECt on it and then iterate through the variable names.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

南渊 2024-09-22 03:46:18

从这里开始

select * from information_schema.PARAMETERS
where SPECIFIC_NAME = 'YourStoredProcedureName'
order by ORDINAL_POSITION

查找parameter_name、data_type、parameter_mode

start here

select * from information_schema.PARAMETERS
where SPECIFIC_NAME = 'YourStoredProcedureName'
order by ORDINAL_POSITION

look for parameter_name, data_type, parameter_mode

锦欢 2024-09-22 03:46:18

SQL-Server本机方式:

select      type_name(system_type_id) as type_name
              , parameter_id
              , name
              , max_length
from          sys.parameters
where        object_id = object_id(N'{schema}.{name}');

SQL-Server native way:

select      type_name(system_type_id) as type_name
              , parameter_id
              , name
              , max_length
from          sys.parameters
where        object_id = object_id(N'{schema}.{name}');
一抹淡然 2024-09-22 03:46:18

踢屁股!!!!!

我用它来生成 ADO 参数以完成经典的 ASP 苦差事。你节省了我几个小时!
更改 PROCEDURE dbo.createParms @procname VARCHAR(200) as

SELECT 'dbCommand.Parameters.Append (dbCommand.CreateParameter("'+ parameter_name + '"' + 
    ',' 
    + CASE WHEN data_type='char' THEN 'adChar'
    WHEN data_type='varchar' THEN 'adVarChar'
    WHEN data_type='int' THEN 'adInteger'
    WHEN data_type='text' THEN 'adLongVarchar'
    WHEN data_type='datetime' THEN 'adDBTimeStamp'
    WHEN data_type='bit' THEN 'adBoolean'
    WHEN data_type='uniqueidentifier' THEN 'adGuid'
    end
    +',adParamInput,'
    +CASE WHEN data_type='int' THEN '0' 
        WHEN  data_type='datetime' THEN '0'
        WHEN data_type='varchar' THEN CONVERT(VARCHAR,character_maximum_length)
        WHEN data_type='char' THEN CONVERT(VARCHAR,character_maximum_length)
        WHEN data_type='text' THEN 'len('+replace(parameter_name,'@','')+')'
        WHEN data_type='bit' THEN '0'
        WHEN data_type='uniqueidentifier' THEN '0'
     end
    + ','+replace(parameter_name,'@','') +'))' AS parm
from information_schema.PARAMETERS
where SPECIFIC_NAME = @procname

Kick ass!!!!!

I was using it to generate ADO parameters for classic asp drudgery. You saved me hours!!
alter PROCEDURE dbo.createParms @procname VARCHAR(200) as

SELECT 'dbCommand.Parameters.Append (dbCommand.CreateParameter("'+ parameter_name + '"' + 
    ',' 
    + CASE WHEN data_type='char' THEN 'adChar'
    WHEN data_type='varchar' THEN 'adVarChar'
    WHEN data_type='int' THEN 'adInteger'
    WHEN data_type='text' THEN 'adLongVarchar'
    WHEN data_type='datetime' THEN 'adDBTimeStamp'
    WHEN data_type='bit' THEN 'adBoolean'
    WHEN data_type='uniqueidentifier' THEN 'adGuid'
    end
    +',adParamInput,'
    +CASE WHEN data_type='int' THEN '0' 
        WHEN  data_type='datetime' THEN '0'
        WHEN data_type='varchar' THEN CONVERT(VARCHAR,character_maximum_length)
        WHEN data_type='char' THEN CONVERT(VARCHAR,character_maximum_length)
        WHEN data_type='text' THEN 'len('+replace(parameter_name,'@','')+')'
        WHEN data_type='bit' THEN '0'
        WHEN data_type='uniqueidentifier' THEN '0'
     end
    + ','+replace(parameter_name,'@','') +'))' AS parm
from information_schema.PARAMETERS
where SPECIFIC_NAME = @procname
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文