`
pzmayf
  • 浏览: 146436 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

对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)

二.修改类
5.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数据),
这样的查询就叫跨域查询.
1.sql:variable()方法,可以在XQuery或XML DML表达式中应用SQL变量的值.
2.sql:column()方法,可以在XQuery或XML DML表达式中使用来自关系列的值.

1.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

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/pzmayf/archive/2007/12/13/1932660.aspx

分享到:
评论

相关推荐

    SQL Server中读取XML文件的简单做法

    在SQL Server中,读取XML文件并对其进行处理是数据库...在SQL Server的后续版本中,如SQL Server 2005及更高版本,处理XML的功能得到了显著增强,例如引入了XML数据类型和更强大的XML方法,使得XML操作更加简便高效。

    XML操作函数详解-SQL Server 2005

    XML操作在SQL Server 2005中是一个重要的功能,它允许数据库管理员和开发者对存储在数据库中的XML数据进行查询、修改和分析。在SQL Server 2005中,XML字段的操作主要涉及以下几个核心函数: 1. **query()** 方法:...

    SQL SERVER 2005 操作 XML

    4. **内置XML函数**:SQL Server 2005提供了丰富的内置XML函数,如`value()`、`exist()`、`query()`和`nodes()`等,这些函数使用户能够方便地操作XML文档。`value()`用于提取XML节点的值,`exist()`检查XML文档是否...

    Microsoft SQL Server 2005 向后兼容组件SQLServer2005_BC.msi

    8. **XML支持**:SQL Server 2005对XML进行了增强,支持XML数据类型,可以将XML直接存储在数据库中,并提供了XML索引和XML函数。 9. **Service Broker**:是SQL Server的异步消息处理系统,用于在数据库之间或...

    SQL Server 2005中XML存取原理剖析.pdf

    为了深入理解SQL Server 2005中XML数据存取的原理,我们需要具体分析以下几个方面: 首先,要了解SQL Server 2005为XML数据类型提供的本地支持。这包括XML数据类型在数据库中的表现形式、存储方式以及如何被SQL ...

    SQLServer20052008 XML数据类型操作

    根据给定的文件标题、描述、标签以及部分内容,本文将详细介绍如何在SQL Server 2005 和 2008 中操作XML数据类型,并简要介绍与之相关的C# XML操作方法。 ### 一、SQL Server 2005/2008 XML 数据类型操作 #### 1. ...

    sqlserver2005的base64加密解密函数

    在SQL Server 2005中,没有内置的Base64加密函数。但我们可以自定义T-SQL存储过程来实现这个功能。以下是一个简单的Base64编码的示例: ```sql CREATE FUNCTION [dbo].[Base64Encode](@input NVARCHAR(MAX)) ...

    SQL Server 2005对XML的支持分析报告.pdf

    SQL Server 2005提供了丰富的内置函数和方法来处理XML数据,如SELECT语句中的FOR XML子句用于生成XML格式的结果集,而XML方法如.value()、.exist()和.modify()则用于读取、验证和修改XML数据。这些功能使得在SQL ...

    SQLServer的内置XML支持

    在SQLServer中,可以将XQuery表达式嵌入到T-SQL语句中,实现对XML数据的复杂查询和操作。 五、XML和关系数据的互操作性 SQLServer提供了无缝的方式来在XML和关系数据之间进行转换。例如,你可以将关系表中的数据...

    Microsoft SQL Server 2005 中的 XML 选项

    结论上,理解SQL Server 2005中XML的不同选项及其用途对于开发高效、可靠的XML应用程序至关重要。开发者应根据实际需求,如性能、数据管理、集成深度等因素,谨慎选择合适的方法。此外,随着技术的不断演进,SQL ...

    Microsoft SQL Server 2005 中的 XML 支持

    ### Microsoft SQL Server 2005 中的 XML 支持 #### 可扩展标记语言 (XML) 的重要性 XML(可扩展标记语言)是一种通用的、与平台无关的数据表示形式,被广泛应用于多种场景中,包括不同系统间的通信、企业到企业的...

    SQL Server 2005 XML专业编程

    SQL Server 2005引入了一套新的XML函数,如SELECT INTO、OPENXML、FOR XML等,这些函数使得在SQL查询中处理XML变得直观和简单。读者将学习到如何利用这些函数来提取、修改和插入XML数据,以及如何构建复杂的XML查询...

    Professional SQL Server 2005 XML

    综上所述,《Professional SQL Server 2005 XML》是一本全面介绍SQL Server 2005中XML功能的专业书籍。它不仅涵盖了从服务器端到客户端处理的所有方面,还深入探讨了.NET Framework和ADO.NET的新特性和增强功能。...

    SQL Server 2005与XML的紧密整合(下)

    在SQL Server 2005中,XML与数据库的整合是一个重要的里程碑,它极大地扩展了SQL Server的功能,使之成为处理结构化和半结构化数据的理想平台。本篇将深入探讨SQL Server 2005与XML的紧密整合,以及如何利用这一特性...

    SQL Server 2005对XML的增强支持.pdf

    下面是一个示例,展示了如何在SQL Server 2005中使用XML数据类型创建表,并插入XML文档实例。 ```sql CREATE DATABASE Demo; USE Demo; GO CREATE TABLE docs(pk INT PRIMARY KEY IDENTITY, xCol XML NOT NULL); ...

    Professional SQL Server 2005 XML代码

    《Professional SQL Server 2005 XML代码》是针对SQL Server 2005数据库管理系统中XML特性的深度解析和实践指南。XML(eXtensible Markup Language)在2005年版本的SQL Server中得到了显著提升,使得数据库与Web服务...

    SQL Server 2005 XML应用开发 光盘

    木书简要介绍了XML语言的编写与规范,重点介绍了SQL Server 2005中XML语言的应用,包括XML数据类型、XQuery语言、FOR XML子句、OPENXML函数、XML模板、updategram模板、XML Bulk Load数据批量处理以及XML Web服务等...

    SQL server2005(百度云下载哦)包含64位和32位的安装包

    5. **XML支持**:SQL Server 2005内建对XML的支持,可以将XML数据存储为第一类公民,并提供了处理XML数据的内置函数。 6. **分析和报表**:SQL Server Analysis Services支持多维数据集和数据挖掘,而Reporting ...

    关于SQL Server 2005中XML数据存储的研究.pdf

    在深入探讨SQL Server 2005中XML数据存储的研究之前,先了解一下XML和数据库的基本概念是很有帮助的。XML,全称为可扩展标记语言,是一种用于存储和传输数据的标记语言。它允许用户自定义标记来表示数据的结构,使得...

Global site tag (gtag.js) - Google Analytics