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
)