日期:2014-05-16  浏览次数:20378 次

将xml转换成列值
有一个xml数据类型的数据如下:
<row>
    <guid>1001a</guid>
   <userId>admin</userId>
   <email>103213455@qq.com</email>
    <tel>13625374857</tel>
    ..........
</row>
我写了一个函数,将xml数据类型的数据转换成表列显示
guid                 userId                email                                            tel                                   ......
1001a             admin                103213455@qq.com               13625374857              .......


现在有大概5000个xml,需要转换成表列显示,大概需要花费40秒的时间,有什么办法,可以提高性能,我使用的是
 @xml.nodes('/row/*') 方式转换

select max(case when t.v.value('local-name(.)','varchar(100)')='GUID' then t.v.value('.','varchar(36)') else null end) as [GUID],
max(case when t.v.value('local-name(.)','varchar(100)')='UserId' then t.v.value('.','varchar(20)') else null end) as [UserId],
.....
   from @xml.nodes('/row/*') t(v)



求达人,求解决方案~~~~
------解决方案--------------------
DECLARE @s XML,@idoc INT
SET @s='<row>
     <guid>1001a</guid>
    <userId>admin</userId>
    <email>103213455@qq.com</email>
     <tel>13625374857</tel>
 </row>'
 
 EXEC sp_xml_preparedocument @idoc OUTPUT, @s
 BEGIN TRY
BEGIN TRAN
SELECT
*
FROM OPENXML (@idoc, 'row',3)
WITH 
(
[guid] varchar(50) 'guid[1]',
[userId] varchar(50) 'userId[1]',
[email] nvarchar(50) 'email[1]',
[tel] varchar(50) 'tel[1]'
)
 
 COMMIT TRAN

END TRY
BEGIN CATCH
DECLARE @Error NVARCHAR(200)
SET @Error=ERROR_MESSAGE()
RAISERROR 50001 @Error
ROLLBACK TRAN
END CATCH

EXEC sp_xml_removedocument @idoc

/*guid                                               userId                                             email          &n