2006-10-16

SQL Server 2005的XML数据修改语言

来源: 本站收集整理 作者:佚名 评论 0 条
 

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

作者:张洪举 Microsoft MVP

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

*

本页内容

1.insert1.insert
2.delete2.delete
3.replace3.replace

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


1.insert

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

insert

Expression1 (

{as first | as last} into | after | before

Expression2

)

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 xml

SET @myDoc = '<root>

<item ID="1">

</item>

</root>'

SELECT @myDoc

-- 插入item的第1个子节点,此时不需要指定as first或as last

SET @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 @myDoc

GO




共5页: 上一页 1 [2] [3] [4] [5] 下一页
(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:SQL Server连接失败错误分析与排除  
下一篇:用SQL 2005的ROW_NUMBER() 实现分页功能
    评论加载中…
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号