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 に答える