SQL xml转table


创建虚拟表@Tmp

DECLARE @Tmp TABLE(ID INT,Resulr XML)

--插入数据

INSERT INTO @Tmp (ID,Resulr) VALUES (1,'<root><row><ID>1</ID><score>80</score></row><row><ID>2</ID><score>85</score></row></root>')
INSERT INTO @Tmp (ID,Resulr) VALUES (2,'<root><row><ID>1</ID><score>90</score></row><row><ID>2</ID><score>75</score></row></root>')

--原结果集

SELECT * FROM @Tmp AS t

<root>
  <row>
    <ID>1</ID>
    <score>80</score>
  </row>
  <row>
    <ID>2</ID>
    <score>85</score>
  </row>
</root>

--查询结果

SELECT t.ID,a.c1.value('ID[1]','int') AS xID
    ,a.c1.value('score[1]','int') AS score
FROM @Tmp AS t CROSS APPLY t.Resulr.nodes('root/row') a (c1)

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM