Tsql 将XML数据反序列化到表中

Tsql 将XML数据反序列化到表中,tsql,Tsql,可能重复: 我得到了这个XML对象: <params> <item> <idtype>1</idtype> <name>dsf2</name> <value>2012-10-05 23:59:59</value> </item> <item> <idtype>2&

可能重复:

我得到了这个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>

1.
dsf2
2012-10-05 23:59:59      
2.
msm1
999
如何将值数据保存到如下表中:

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
)