2

可能重复:
反序列化 T-SQL 中的 XML 数据对象

我有这个 XML 对象:

<params>
    <item>
        <idtype>1</idtype>
        <name>dsf2</name>
        <value>2012-10-05 23:59:59</value>      
    </item>

    <item>
        <idtype>2</idtype>
        <name>msm1</name>
        <value>999</value>      
    </item>
</params>

如何将值数据保存到这样的表中:
在此处输入图像描述

4

1 回答 1

6
DECLARE @XML XML = '<params>
    <item>
        <idtype>1</idtype>
        <name>dsf2</name>
        <value>2012-10-05 23:59:59</value>      
    </item>

    <item>
        <idtype>2</idtype>
        <name>msm1</name>
        <value>999</value>      
    </item>
</params>'

INSERT INTO [TableName] ([idtype], [name], [value])
SELECT    
    [idtype] = TypeNode.value('(idtype)[1]', 'int'),
    [name] = TypeNode.value('(name)[1]', 'nvarchar(50)'),
    [value] = TypeNode.value('(value)[1]', 'nvarchar(50)')
FROM
    @XML.nodes('/params/item') AS XTbl(TypeNode)

顺便说一句:我假设您的表是按以下方式定义的:

CREATE TABLE [TableName](
    [idtype] [int] NULL,
    [name] [nvarchar](50) NULL,
    [value] [nvarchar](50) NULL
)
于 2012-11-26T13:24:04.983 回答