下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

教你怎样在SQLServer中用XQuery分解XML数据

作者:课课家     来源: http://www.kokojia.com/点击数:674发布时间: 2015-11-06 10:46:51

标签: SQL ServerWebXML

大神带你学编程,欢迎选课

  

      欢迎来到小编的文章进行学习阅读,想必大家又有很多问题吧,在这里会有你想要收获的答案,请大家慢慢学习吧!计算机编辑语言

       在举例说明如何分解上一篇文章中的数据时,我们首先了解一下XQuery和它在SQL Server 2005中为开发者提供的功能。

  XQuery介绍
  XQuery,也称作XML Query,是一种查询XML数据的语言,允许你提取所需的节点和元素。它由W3C定义,可用于今天的大多数主流数据库引擎中,如Oracle、DB2和SQL Server。
  SQL Server 2005 XQuery函数
  下面的四个函数是SQL Server 2005中的XQuery函数。(注意,XML、XQuery语句和下面的函数都区分大小写。例如,SQL编译器接受XML数据中的.exist,但拒绝.EXIST或.Exist。)
  xml.exist
  这个方法根据一个XML节点上的搜索表达式返回一个布尔值。例如,列表A中XML代码片段中的语句将返回1(真):
  SELECT @x.exist('/christmaslist/person[@gift = "socks"]')
  这个语句返回0(假):
  SELECT @x. exist ('/christmaslist/zach')
  由于“Socks”一词被封套,这个语句将返回0(假)。
  SELECT @x.exist('/christmaslist/person[@gift = "socks"]')
  xml.value
  这个方法接受一个XQuery语句并返回一个单独值。使用列表A中同样的XML代码片段,不可以使用VALUE函数生成“betty”值,如下所示:
  SELECT @x.value('/christmaslist[1]/person[1]/@name', 'VARCHAR(20)')
  而XQuery生成“zach”值。
  SELECT @x.value('/christmaslist[1]/person[2]/@name', 'VARCHAR(20)')
  xml.query
  这个方法接受一个XQuery并返回一个XML数据类型的实例。可以按需要将这些查询简单或复杂化,下面是一个简单的例子:
  SELECT @x.query('/christmaslist/person')
  它返回XML文件:
  以下是引用片段:
      编程语言(programming language),是用来定义计算机程序的形式语言。它是一种被标准化的交流技巧,用来向计算机发出指令。一种计算机语言让程序员能够准确地定义计算机所需要使用的数据,并精确地定义在不同情况下所应当采取的行动。[1]
最早的编程语言是在电脑发明之后产生的,当时是用来控制提花织布机及自动演奏钢琴的动作。在电脑领域已发明了上千不同的编程语言,而且每年仍有新的编程语言诞生。很多编程语言需要用指令方式说明计算的程序,而有些编程语言则属于声明式编程,说明需要的结果,而不说明如何计算。编辑语言排行榜


  xml.nodes


  在你需要将一个XML数据类型变量中的数据分解到关系数据中时,这个方法十分有用。这个方法接受一个XQuery语句作为参数,并返回一个包含XML变量逻辑标量数据的行集。列表B中的查询利用上面定义的XML变量,并将数据分解到一个结果集中,它显示在XML变量中定义的人物姓名。

c语言编程入门
  修改OPENXML存储过程
  现在我来说明如何修改上周的OPENXML存储过程,使其可以应用XQuery功能。首先,我往XML变量中加载一些数据。如列表C所示。我们可以建立一个接受XML参数的过程,再应用XQuery函数把XML文件中的数据插入一个表中,而不必应用OPENXML。如列表D所示。
  最初在数据库中应用XML似乎有些难于处理,还要花一些时间习惯使用XQuery和Xpath查询。但是,经过一段时间的学习以后,你就会发现在数据库中应用XML数据相当实用。
  例如,在上述存储过程中应用XML数据,你只需调用一次数据库,而不必像典型存储过程编程那样调用N次数据库。这二者似乎区别不大,但对一个繁忙的系统而言,应用XML数据会有很大益处。而且,应用XQuery而非OPENXML还会显著提高性能,对小型XML文件更是如此。


更多视频课程文章的课程,可到课课家官网查看。我在等你哟!!!

赞(109)
踩(4)
分享到:
华为认证网络工程师 HCIE直播课视频教程