- 3
- 0
- 约2.18万字
- 约 13页
- 2017-01-09 发布于重庆
- 举报
sql2005更新xml.
sql 2005 更新xml 分类: SQL相关 2009-10-12 09:59 345人阅读 评论(0) 收藏 举报 1.insertinsert用于将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 titleSQL 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 titleSQL Server 2005的新增功能/title as first into (/root/item)[2]) SELECT @myDoc GO图1 向XML中插入节点(2)插入多个元素到文档中在下面的示例中,将title和author元素插入到了item节点中。元素之间使用逗号分隔,并包含在括号中。DECLARE @myDoc xml SET @myDoc = root item ID=1 /item /root SELECT @myDoc SET @myDoc.modify(insert (titleSQL Server 2005开发宝典/title,author张洪举/author) into (/root/item)[1]); SELECT @myDoc GO(3)插入属性到文档中在下面的示例中,向XML文档中插入了多个属性。每次插入属性后,SELECT语句都会显示结果,最终执行结果如图2所示。DECLARE @myDoc xml SET @myDoc = rootitem ID=1titleAjax实战/titleauthor张洪举/author/item/root SELECT @myDoc SET @myDoc.modify(insert attribute ShipTo {广州} into (/root/item[@ID=1])[1]); SELECT @myDoc-- 通过一个sql变量指定要插入属性ShipDate的值 DECLARE @ShipDate char(11) SET @ShipDate
原创力文档

文档评论(0)