SQL server 2005中XML文件问题.doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL server 2005中XML文件问题

首先要明确一个基本原则,XML类型的数据之间以及XML类型与其它数据类型之间都是不能比较的,也就是说XML类型的数据不能出现在等号的任何一边。 大致可分为查询类,修改类和跨域查询类。 查询类包含query(),value(),exist()和nodes(). 修改类包含modify(). 跨域查询类包含sql:variable()和sql:column(). 查询类 1. query()方法:返回满足条件的所有XML行。只能用于SELECT子句当中。 2. value()方法:返回从XML节点中提取的标量值。必须在value()方法的第二个参数中指定所返回的标量的数据类型,所以value()方法可以与其它标量进行比较。可用于SELECT子句和WHERE子句。 3. exist()方法:返回int型标量的0或者1。对每行的XML数据类型进行存在性检查。可用于SELECT子句和WHERE子句。 4. nodes()方法:返回只有一个栏位的table,且该table的栏位是XML数据类型。所以nodes()方法只能出现在FROM子句中。 示例: 1.query() SELECT pk, xCol.query(/doc[@id = 123]//section) FROM docs 2.value() SELECT xCol.value(data((/doc//section[@num = 3]/heading)[1]), nvarchar(max)) FROM docs 3.exist() SELECT xCol.query(/doc[@id = 123]//section) FROM docs WHERE xCol.exist (/doc[@id = 123]) = 1 4.nodes() SELECT nref.value(@genre, varchar(max)) LastName FROM docs CROSS APPLY xCol.nodes(//book) AS R(nref) 修改类 modify()方法:允许修改XML实例的某些部分,例如添加或删除子树,或者更新标量值(如将书的价格从9.99替换为39.99)。 无返回值,只能用于SET子句中。 --在指定位置添加子树(insert...after...) UPDATE docs SET xCol.modify( insert <section num=2> <heading>Background</heading> </section> after (/doc/section[@num=1])[1]) --更改指定节点中的标量值(replace...with...) UPDATE XmlCatalog SET Document.modify ( default namespace = http://myBooks replace value of (/bookstore/book[@ISBN= 1-8610-0311-0]/price)[1] with 49.99) 跨域查询类 如果数据驻留在关系数据类型的列和XML数据类型的列的组合中,就可能需要编写查询来组合关系数据处理和XML数据处理(组合的对象还可以是标量数据类型的SQL变量和XML数据),这样的查询就叫跨域查询。 sql:variable()方法:可以在XQuery或XML DML表达式中应用SQL变量的值。 sql:variable() DECLARE @isbn varchar(20) SET @isbn = 0-7356-1588-2 SELECT xCol FROM docs WHERE xCol.exist (/book[@ISBN = sql:variable(@isbn)]) = 1 sql:column()方法:可以在XQuery或XML DML表达式中使用来自关系列的值。 详解SQL中FOR XML子句的各种用法 FOR XML子句有四种最基本的模式,如上图所示: 1、AUTO模式:返回数据表为起表名的元素,每一列的值返回为属性; 2、RAW模式:返回数据行为元素,每一列的值作为元素的属性; 3、PATH模式:通过简单的XPath语法来允许用户自定义嵌套的XML结构、元素、属性值 4、EXPLICIT模式:通过SELECT语法定义输出XML的结构 具体实例如下: 1、AUTO模式 (1). SQL语句: 1: SELECT EmployeeID,FirstName,LastName FROM Employees FOR XML AUTO, XMLSCHE

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档