加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 12:32:36 所属栏目:MsSql教程 来源:网络整理
导读:为对XQuery语言的扩展,XMLDML为XML数据操作提供了更大的灵活性,而不再仅仅是对XML数据进行一些查询操作。通过XMLDML,用户可以像操作关系表一样对XML中的节点内容进行插入、更新和删除操作。XMLDML需要通过xml数据类型的modify方法进行调用。 1.insert inse
为对XQuery语言的扩展,XMLDML为XML数据操作提供了更大的灵活性,而不再仅仅是对XML数据进行一些查询操作。通过XMLDML,用户可以像操作关系表一样对XML中的节点内容进行插入、更新和删除操作。XMLDML需要通过xml数据类型的modify方法进行调用。

 

  1.insert

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

  insert
Expression1(

  asfirstaslastintoafterbefore

  Expression2

  )

  Expression1和Expression2

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

  into

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

  after

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

  before

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

  (1)插入元素文档中

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

  DECLARE@myDocxml

  SET@myDoc="

  "

  SELECT@myDoc

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

  SET@myDoc.modify("

  insert张洪举

  into(/root/item)1")

  SELECT@myDoc

  -- 插入item的第2个子节点,as first指定插入到同级子节点的前面

  作者:zhanghongju

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读