首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在一个存储过程的单个参数中传递多个值?

如何在一个存储过程的单个参数中传递多个值?
EN

Stack Overflow用户
提问于 2012-05-08 14:19:44
回答 3查看 6.4K关注 0票数 1

我想在一个参数中传递多个值。SQL Server 2005

EN

Stack Overflow用户

发布于 2012-05-12 04:59:52

您可以让存储过程接受一个xml类型的输入变量,然后解压元素并获取它们。例如:

代码语言:javascript
运行
复制
DECLARE @XMLData xml

DECLARE 
    @Code varchar(10),
    @Description varchar(10)

SET @XMLData = 
'
    <SomeCollection>
      <SomeItem>
        <Code>ABCD1234</Code>
        <Description>Widget</Description>
      </SomeItem>
    </SomeCollection>
'

SELECT 
    @Code = SomeItems.SomeItem.value('Code[1]', 'varchar(10)'),
    @Description = SomeItems.SomeItem.value('Description[1]', 'varchar(100)')
FROM @XMLDATA.nodes('//SomeItem') SomeItems (SomeItem)

SELECT @Code AS Code, @Description AS Description

结果:

代码语言:javascript
运行
复制
Code        Description
==========  ===========
ABCD1234    Widget
票数 1
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10493545

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档