从XML碎化数据,导入关系表(SQL Server 2008)

我到处都寻求帮助.

我对这一切都是新手,我发现很难理解它上面的所有文档.

说我有这个XML

<footballteams>
  <team manager="Benitez">
    <name>Liverpool</name>
    <ground>Anfield</ground>
  </team>
  <team manager="Mourinho">
    <name>Chelsea</name>
    <ground>Stamford Bridge</ground>
  </team>
  <team manager="Wenger">
    <name>Arsenal</name>
    <ground>Highbury</ground>
  </team>
</footballteams>

我想从中获取数据并将其加载到名为footballteams(name,manager,ground)的关系表中.

我想在SQL Server 2008中这样做,从我到处读到的一个有用的方法是.nodes()方法,但我只是无法理解如何使用它.

尝试这样的事情:
DECLARE @input XML = '<footballteams>
  <team manager="Benitez">
    <name>Liverpool</name>
    <ground>Anfield</ground>
  </team>
  <team manager="Mourinho">
    <name>Chelsea</name>
    <ground>Stamford Bridge</ground>
  </team>
  <team manager="Wenger">
    <name>Arsenal</name>
    <ground>Highbury</ground>
  </team>
</footballteams>'


SELECT
    TeamName = Foot.value('(name)[1]','varchar(100)'),Manager = Foot.value('(@manager)',Ground = Foot.value('(ground)[1]','varchar(100)')
FROM
    @input.nodes('/footballteams/team') AS Tbl(Foot)

基本上,对.nodes()的调用创建一个名为Tbl的伪“表”,其中一个名为Foot的XML列将包含每个< team> XML节点作为其值.

然后,您可以从该伪表中进行选择,并从该< team>中提取XML属性(@manager)和元素(name,ground)的各个值. XML片段,并将它们转换为您的选择类型的T-SQL数据值.

要将这些值插入表中 – 只需使用基于此的INSERT语句:

;WITH ShreddedData AS
( 
  SELECT
    TeamName = Foot.value('(name)[1]','varchar(100)')
  FROM
    @input.nodes('/footballteams/team') AS Tbl(Foot)
)
INSERT INTO dbo.FootballTeams(Name,Manager,Ground)
   SELECT TeamName,Ground
   FROM ShreddedData

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇