将XML数据存储在表中

时间:2013-06-06 07:07:25

标签: mysql sql

我有格式的XML数据:

<Display>
 <StoreCode>1234</StoreCode>
 <TerminalID>02</TerminalID>
 <TrnsNo>0123456789</TrnsNo>
 <Date>03-05-2013</Date>
 <Time>11:30</Time>
 <Vdtls>
  <VID>VVB0000015</VID>
  <VID>VVB0000016</VID>
 </Vdtls>
</Display>

我已将此xml数据存储在表的列中。 现在我想解析这个XML并将其存储在另一个具有结构的表中。

 CREATE TABLE [dbo].[temp_XMLreceivedData]
 (
[StoreCode] [int] NULL,
[TerminalId] [int] NULL,
[TransactionNo] [varchar](10) NULL,
[RequestDate] [date] NULL,
[RequestTime] [char](5) NULL,
[VoucherDetails] [varchar](10) NULL
 ) 

如何实现这一目标?

2 个答案:

答案 0 :(得分:0)

尝试以下代码

insert into temp_XMLreceivedData
select 
a.b.value('(StoreCode/node())[1]','VARCHAR(10)') ,
a.b.value('(TerminalID/node())[1]','VARCHAR(100)'),
a.b.value('(TrnsNo/node())[1]','VARCHAR(100)') ,
a.b.value('(Date/node())[1]','VARCHAR(100)') ,
a.b.value('(Time/node())[1]','VARCHAR(100)') ,
a.b.value('(Vdtls/VID/node())[1]','VARCHAR(100)') 
from @XmlTbl.nodes('Display') as a(b)

答案 1 :(得分:0)

我认为整个代码如下

declare @XmlTbl xml

select top(1) @XmlTbl=cast(cast(xmldata as nText) as xml) from test_xml

insert into temp_XMLreceivedData
select 
a.b.value('(StoreCode/node())[1]','VARCHAR(10)') ,
a.b.value('(TerminalID/node())[1]','VARCHAR(100)'),
a.b.value('(TrnsNo/node())[1]','VARCHAR(100)') ,
a.b.value('(Date/node())[1]','VARCHAR(100)') ,
a.b.value('(Time/node())[1]','VARCHAR(100)') ,
a.b.value('(Vdtls/VID/node())[1]','VARCHAR(100)') 
from @XmlTbl.nodes('Display') as a(b)

此代码仅适用于一个数据。如果插入所有数据数据,则循环表