zoukankan      html  css  js  c++  java
  • 【转载】SQL Server 数据类型-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表达式中使用来自关系列的值。

    http://developer.51cto.com/art/200902/111125.htm

  • 相关阅读:
    【学习】018 Spring框架
    【学习】017 Mybatis框架
    【学习】016 MySQL数据库优化
    【学习】 015 Linux相关
    【学习】014 深入理解Http协议
    【学习】013 Servlet、Cookie、Session的简述
    js 异常判断
    CSS 文字概念小记
    Echarts tooltip 坐标值修改
    js 查找当前元素/this
  • 原文地址:https://www.cnblogs.com/zhxhdean/p/2421553.html
Copyright © 2011-2022 走看看