当前位置:首页 > 网络编程 > 数据库 > SQL Server > SQL Server 2008中有关XML的新功能

SQL Server 2008中有关XML的新功能

点击次数:39 次 发布日期:2008-11-21 22:44:46 作者:源代码网
源代码网推荐1 导言

源代码网整理以下Microsoft 在Microsoft SQL Server 2000中推出了与XML相关的功能以及Transact-SQL 关键字FOR XML和OPENXML ,这使得开发人员可以编写Transact-SQL代码来获取XML流形式的查询结果,并将一个XML文档分割成一个rowset。SQL Server 2005显著的扩展了这些XML功能,推出了一个支持XSD schema验证、基于XQuery的操作和XML索引的本地的xml 数据类型。SQL Server 2008建立在之前版本的XML功能基础之上,做了改进来迎接客户在存储和操纵数据库中的XML数据时所面临的挑战。

源代码网整理以下2 SQL Server XML 功能的发展历程

源代码网整理以下SQL Server的XML功能随着从SQL Server2000版本以来的每一个版本而不断发展。在我们检查SQL Server 2008中的改进之前,通过之前的版本来总结XML功能的发展历程可能会比较有用。

源代码网整理以下2.1 SQL Server 2000中的XML功能

源代码网整理以下在SQL Server 2000中,Microsoft 推出了Transact-SQL 关键字FOR XML和OPENXML。FOR XML 是对SELECT语句的扩展,它返回如下面的示例所示的XML流式的查询结果。

源代码网整理以下

  SELECTProductID,ProductName
  FROMProductsProduct
  FORXMLAUTO

源代码网整理以下这个查询返回一个如下面示例所示的XML片断:  

源代码网整理以下

<Product ProductID="1" ProductName="Widget"/>
<Product ProductID="2" ProductName="Sprocket"/>

源代码网整理以下OPENXML 功能执行与FOR XML 条件子句相反的功能,它创建一个XML文档的rowset ,如下面的示例所示:

源代码网整理以下

DECLARE @doc nvarchar(1000)
SET @doc = "<Order OrderID = "1011">
 <Item ProductID="1" Quantity="2"/>
 <Item ProductID="2" Quantity="1"/>
 </Order>"
DECLARE @xmlDoc integer
EXEC sp_xml_preparedocument @xmlDoc OUTPUT, @doc
SELECT * FROM
OPENXML (@xmlDoc, "Order/Item", 1)
WITH
(OrderID integer "../@OrderID",
ProductID integer,
Quantity integer)
EXEC sp_xml_removedocument @xmlDoc

源代码网整理以下注意用sp_xml_preparedocument和sp_xml_removedocument 存储过程来创建XML文档的节点树的一个内存展示的用法。这个Transact-SQL 代码返回下面的rowset。 

源代码网整理以下

OrderID ProductID Quantity
1011 1 2
1011 2 1

源代码网整理以下2.2 SQL Server 2005中的XML功能

源代码网整理以下在SQL Server 2005中,FOR XML 功能得到了增强,它有了对根元素和元素名称的新的选项、使用FOR XML 调用以便你可以建立复杂的层次关系的能力、和一个新的使得你可以定义将要使用XPath 语法来提取的XML结构的PATH 模式,如下面的示例所示:

源代码网整理以下

SELECT ProductID AS "@ProductID",
ProductName AS "ProductName"
FROM Products
FOR XML PATH ("Product"), ROOT ("Products")

源代码网整理以下这个查询返回下面的XML:

源代码网整理以下

<Products>
<Product ProductID="1">
<ProductName>Widget</ProductName>
</Product>
<Product ProductID="2">
<ProductName>Sprocket</ProductName>
</Product>
</Products>

源代码网整理以下除了增强SQL Server 2000已推出的XML功能,SQL Server 2005增加了一个新的、本地的xml 数据类型,使得你可以为XML数据创建变量和列,如下面的示例所示:

源代码网整理以下

CREATE XML SCHEMA COLLECTION ProductSchema AS
"<?xml version="1.0" encoding="UTF-16"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
 <!-- schema declarations go here -->
</xs:schema>"

源代码网整理以下源代码网供稿.

网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华