SQL Server 2005的XML数据修改语言

网络整理 - 07-26

SQL Server 2005的XML数据修改语言(XML DML)
 

作者:张洪举 Microsoft MVP

注:本文章中的内容需要相关的XML和XQuery知识

本页内容

作为对XQuery语言的扩展,XML DML为XML数据操作提供了更大的灵活性,而不再仅仅是对XML数据进行一些查询操作。通过XML DML,用户可以像操作关系表一样对XML中的节点内容进行插入、更新和删除操作。XML DML需要通过xml数据类型的modify方法进行调用。


1.insert

insert用于将Expression1标识的一个或多个节点作为Expression2标识的节点的子节点或同级节点插入。语法格式如下:

insertExpression1 ({as first | as last} into | after | beforeExpression2)

Expression1和Expression2

标识要插入的一个或多个节点。它可以是常量XML实例,也可以是XQuery表达式。该表达式可以得出节点、文本节点或一组有序的节点,但它无法解得根节点。如果该表达式得出一个值或一组值,则这些值作为单个文本节点插入,各值之间以空格分隔开。如果将多个节点指定为常量,则这些节点用括号括住,并以逗号分隔开。但无法插入异构序列(如一组元素、属性或值)。如果Expression1解得一个空序列,则不会发生插入操作,并且不会返回任何错误。

into

Expression1标识的节点作为Expression2标识的节点的子节点插入。如果Expression2中的节点已有一个或多个子节点,则必须使用as first或as last来指定所需的新节点添加位置。

after

Expression1标识的节点作为Expression2标识的节点的同级节点直接插入在其后面,after关键字不能用于插入属性。

before

Expression1标识的节点作为Expression2标识的节点的同级节点直接插入在其前面,before关键字不能用于插入属性。

(1)插入元素文档中

在下面的示例中,首先将XML文档分配给xml类型的变量。然后使用几个insert XML DML语句说明如何将元素节点插入文档中。注意在示例中为各种路径表达式都指定了“[1]”,以要求每次只返回单个目标,这样就确保了只有单个目标节点。每次插入后,SELECT语句都会显示结果。最终执行结果如图1所示。

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"></item></root>'SELECT @myDoc-- 插入item的第1个子节点,此时不需要指定as first或as lastSET @myDoc.modify('insert <author>张洪举</author>into (/root/item)[1]')SELECT @myDoc-- 插入item的第2个子节点,as first指定插入到同级子节点的前面SET @myDoc.modify('insert <title>SQL Server 2005开发宝典</title>as first into (/root/item)[1]')SELECT @myDoc-- 插入第2个item节点SET @myDoc.modify('insert <item ID="2"></item>into (/root)[1]')SELECT @myDoc-- 向第2个item中插入第1个子节点SET @myDoc.modify('insert <title>SQL Server 2005的新增功能</title>as first into (/root/item)[2]')SELECT @myDocGO

a

图1 向XML中插入节点

(2)插入多个元素到文档中

在下面的示例中,将<title>和<author>元素插入到了item节点中。元素之间使用逗号分隔,并包含在括号中。

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"></item></root>'SELECT @myDocSET @myDoc.modify('insert (<title>SQL Server 2005开发宝典</title>,<author>张洪举</author>)into (/root/item)[1]');SELECT @myDocGO

(3)插入属性到文档中

在下面的示例中,向XML文档中插入了多个属性。每次插入属性后,SELECT语句都会显示结果,最终执行结果如图2所示。

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item></root>'SELECT @myDocSET @myDoc.modify('insert attribute ShipTo {"广州"}into (/root/item[@ID=1])[1]');SELECT @myDoc-- 通过一个sql变量指定要插入属性ShipDate的值DECLARE @ShipDate char(11)SET @ShipDate='2006-01-23Z'SET @myDoc.modify('insert attribute ShipDate {sql:variable("@ShipDate") cast as xs:date ?}into (/root/item[@ID=1])[1]') ;SELECT @myDoc-- 插入多个属性,属性之间使用逗号分隔,并包含在括号内SET @myDoc.modify('insert (attribute PostCode {"253020" },attribute Weight {"1.5"})into (/root/item[@ID=1])[1]');SELECT @myDocGO

a

图2插入属性到XML中

(4)插入注释节点

在下面的示例中,将注释节点插入到ID为2的item节点中<title>元素的后面。

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item><item ID="2"><title>ASP.NET实战</title><author>卢桂章</author></item></root>'SET @myDoc.modify('insert <!-- 注释 -->after (/root/item[@ID=2]/title)[1]');SELECT @myDocGO

插入注释后XML的内容如下:

<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item><item ID="2"><title>ASP.NET实战</title><!-- 注释 --><author>卢桂章</author></item></root>

(5)使用CDATA部分插入数据

当插入的文本中包含有XML无效字符(如“<”或“>”)时,可以使用CDATA部分插入数据。参考下面的示例:

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item><item ID="2"><title>ASP.NET实战</title><author>卢桂章</author></item></root>'SET @myDoc.modify('insert <desc><![CDATA[ <送货方式>上门<价款>未收]]></desc>into (/root/item[@ID=2])[1] ') ;SELECT @myDocGO

被插入部分中的XML无效字符,会被转换成实体,如“<”保存为<。下面的插入CDATA部分后XML文档的内容:

<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item><item ID="2"><title>ASP.NET实战</title><author>卢桂章</author><desc> <送货方式>上门<价款>未收</desc></item></root>

(6)插入文本节点

要将文件插入到XML中,需要使用text函数构造文本,参考下面的示例:

DECLARE @myDoc xmlSET @myDoc = '<root><item ID="1"><title>Ajax实战</title><author>张洪举</author></item></root>'SET @myDoc.modify('insert text{"订单列表"}as first into (/root)[1]');SELECT @myDocGO