摘要:sql中的for xml语法为表转化为xml提供了很好的支持,当然使用同样的程序语言也能够达到同样的效果,但是有了for xml将使得这一切更加的方便。

主要内容:

Select 的查询结果会作为行集返回,但是你同样可以在sql中指定for xml子句使得查询作为xml来检索。在for xml子句中,可以指定以下模式之一:RAW 、AUTO、EXPLICIT和PATH。

RAW模式返回行为元素,每一列的值作为元素的属性;AUTO模式返回表名为节点的元素,每一列的属性作为属性输出;EXPLICIT模式通过SELECT语法定义输出XML结构;PATH模式中列名或列别名作为XPATH表达式来处理。

下面是四种方式输出的效果

RAW模式

SELECT TOP 5 ProductName,UnitPrice FROM dbo.Products FOR XML RAW

查询结果

<row ProductName="Chai" UnitPrice="18.0000" />
<row ProductName="Chang" UnitPrice="19.0000" />
<row ProductName="Aniseed Syrup" UnitPrice="10.0000" />
<row ProductName="Chef Anton's Cajun Seasoning" UnitPrice="22.0000" />
<row ProductName="Chef Anton's Gumbo Mix" UnitPrice="21.3500" />

AUTO模式

SELECT TOP 5 ProductName,UnitPrice FROM dbo.Products FOR XML AUTO

查询结果

<dbo.Products ProductName="Chai" UnitPrice="18.0000" />
<dbo.Products ProductName="Chang" UnitPrice="19.0000" />
<dbo.Products ProductName="Aniseed Syrup" UnitPrice="10.0000" />
<dbo.Products ProductName="Chef Anton's Cajun Seasoning" UnitPrice="22.0000" />
<dbo.Products ProductName="Chef Anton's Gumbo Mix" UnitPrice="21.3500" />

EXPLICIT模式

SELECT TOP 5 1 AS Tag,0 AS Parent, OrderID AS [Order!1!ID],OrderDate AS [Order!1!Date],CustomerID AS [Order!1!Customer],NULL AS [OrderDetail!2!ProductID],NULL AS [OrderDetail!2!UnitPrice],NULL AS [OrderDetail!2!Quantity] FROM dbo.Orders WHERE dbo.Orders.OrderID='10248'
UNION ALL
SELECT TOP 5 2 AS Tag,1 AS Parent, NULL,NULL ,NULL,ProductID,UnitPrice,Quantity FROM dbo.[Order Details] WHERE OrderID='10248'
FOR XML EXPLICIT

查询结果

<Order ID="10248" Date="1996-07-04T00:00:00" Customer="VINET">
<OrderDetail ProductID="11" UnitPrice="14.0000" Quantity="12" />
<OrderDetail ProductID="42" UnitPrice="9.8000" Quantity="10" />
<OrderDetail ProductID="72" UnitPrice="34.8000" Quantity="5" />
</Order>

PATH模式

SELECT TOP 5 ProductName AS Name, UnitPrice AS Price FROM dbo.Products FOR XML PATH('Cmj')

查询结果

<Cmj>
<Name>Chai</Name>
<Price>18.0000</Price>
</Cmj>
<Cmj>
<Name>Chang</Name>
<Price>19.0000</Price>
</Cmj>
<Cmj>
<Name>Aniseed Syrup</Name>
<Price>10.0000</Price>
</Cmj>
<Cmj>
<Name>Chef Anton's Cajun Seasoning</Name>
<Price>22.0000</Price>
</Cmj>
<Cmj>
<Name>Chef Anton's Gumbo Mix</Name>
<Price>21.3500</Price>
</Cmj>

RAW模式和AUTO模式相对比较简单,灵活性当然也是比较差的。EXPLICIT模式会将查询执行生成的行集转换为XML文档,也就是说结构可以自定义,当然这必须符合一定的格式。就拿上面的语句来说:

Tag指定生成节点的嵌套级别,列名必须为"Tag"例如上面的级别为1。

Parent指定当前Tag的父级层次,列名必须为"Parent",NULL表示顶级。

其他列名,例如[Order!1!ID]分别代表元素名称、Tag标记(也就是层级)、属性名称。例如上面的这一列就代表会在第一级节点中生成一个节点名称为Order的节点并且有一个属性ID。

此外还需要指出的是这个列名还有一个可选部分,完整的形式是[ElementName!TagNumber!AttributeName!Directive],最后一部分Directive是可选的,如果不指定的话默认作为ElementName中的属性名称;当然如果制定了xml、cdata或者element那么它将作为ElementName的一个子元素而不是属性。并且指定了此选项之后AttributeName可以为空。

上面的例子中如果去掉For XML EXPLICIT之后查询到的数据时如下形式:

按照上面的规则不难看出,FOR XML EXPLICIT会按照顺序生成xml:

第一次执行(第一行数据)时tag为1,parent为0,则此时会按照列名创建一个Order节点,并依次创建三个属性:ID、Date和Customer,其值为:10248、1996-07-04 00:00:00.000、VINET。此时不会生成ProductID属性,因为它的Tag为2,需要在第二级节点中创建,其他另个属性也是如此。

第二次执行(第二行数据)时Tag为2,Parent为1,也就是要在Tag为1的节点中创建一个2级节点。然后根据查找列名中Tag为2的列,依次创建ProductID、UnitPrice、Quantity属性,并赋值。

第三次、第四次同第二次执行类似,不同的只是数据而已。

PATH模式应该说是使用率相当高的,原因比较简单,它的使用既简单又灵活。在PATH模式中,节点名称可以使列名也可以通过别名指定又或者根本不指定,不指定的情况下就只显示节点内数据;根节点可以指定也可以不指定,不指定情况下默认为"row",并且根节点指定为""的情况下可以完全取消根节点的显示。有了这一属性就可以使用PATH模式完成很多有用的操作。

没有指定根节点时:

SELECT TOP 5 ProductName FROM dbo.Products FOR XML PATH
<row>
<Name>Chai</Name>
<Price>18.0000</Price>
</row>
<row>
<Name>Chang</Name>
<Price>19.0000</Price>
</row>
<row>
<Name>Aniseed Syrup</Name>
<Price>10.0000</Price>
</row>
<row>
<Name>Chef Anton's Cajun Seasoning</Name>
<Price>22.0000</Price>
</row>
<row>
<Name>Chef Anton's Gumbo Mix</Name>
<Price>21.3500</Price>
</row>

去掉根节点名称:

SELECT TOP 5 ProductName FROM dbo.Products FOR XML PATH('')
<ProductName>Alice Mutton</ProductName>
<ProductName>Aniseed Syrup</ProductName>
<ProductName>Boston Crab Meat</ProductName>
<ProductName>Camembert Pierrot</ProductName>
<ProductName>Carnarvon Tigers</ProductName>

去掉根节点和子节点名称:

SELECT TOP 5 ProductName+'' FROM dbo.Products FOR XML PATH('')
Alice MuttonAniseed SyrupBoston Crab MeatCamembert PierrotCarnarvon Tigers

可以发现去掉节点名称之后for xml path起到了字符串连接的作用,这样一来就可以利用这一特性完成字符串拼接,例如下面的语句就能完成可以将五种产品用","进行分割的功能:

SELECT LEFT(ProductNames,(LEN(ProductNames)-1)) FROM(
SELECT
(SELECT TOP 5 ProductName+',' FROM dbo.Products FOR XML PATH('')) AS ProductNames
) AS T

原文地址:崔江涛(KenshinCui)

(Sql Server)SQL FOR XML的更多相关文章

  1. (Sql Server)SQL FOR XML PATH

    FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作.那么以一个实例为主 ...

  2. 大哥带的MSsql注入(SQL Server)--预习

    ①判断数据库类型and exists (select * from sysobjects)--返回正常为mssql(也名sql server)and exists (select count(*) f ...

  3. (4.22)sql server视图/索引视图概念

    (4.22)sql server视图 关键词:sql server视图.索引视图 SQL Server视图是由SQL语句组成的逻辑数据库对象.它也可以称为由SQL语句组成的虚拟表,该SQL语句可能包含 ...

  4. (4.20)sql server性能指标、性能计数器

    (4.20)sql server性能指标.性能计数器 常规计数器 收集操作系统服务器的服务器性能信息,包括Processor.磁盘.网络.内存 Processor 处理器 1.1 % Processo ...

  5. (4.19)sql server中的事务模式(隐式事务,显式事务,自动提交事务)

    (4.19)sql server中的事务模式(隐式事务,显式事务,自动提交事务) 1.概念:隐式事务,显式事务,自动提交事务 2.操作:如何设置事务模式 3.存储过程中的事务 XACT_ABORT 1 ...

  6. (4.1)SQL Server Browser 与动态端口

    转自:http://blog.51cto.com/jimshu/1120295 一.启用TCP端口 1.启用TCP/IP协议 打开SSCM(SQL Server Configuration Manag ...

  7. (4.16)sql server迁移DB文件(同一DB内)

    SQL Server 修改数据库物理文件存在位置 关键词:迁移文件,迁移temp库(这怎么迁移呢,用方法2即可,需要重启实例) 三种均需要离线: 一共分为(1)脱机迁移和(2)在线迁移. (1)迁移方 ...

  8. 开始使用 Docker (Linux 上运行 SQL Server) 上的 SQL Server 容器 - SQL Server | Microsoft Docs

    原文:开始使用 Docker (Linux 上运行 SQL Server) 上的 SQL Server 容器 - SQL Server | Microsoft Docs 快速入门:使用 Docker ...

  9. 批处理创建数据库(Sql Server)

    ylbtech-Miscellaneos:批处理创建数据库(Sql Server) 1.A,资源(Resource) - 创建数据返回顶部 1.A.1,InstallDatabases.cmd - 编 ...

随机推荐

  1. 【mybatis-plus】分页、逻辑删除

    通过mybatis-plus实现分页,也是很简单,插件大法. 一.分页 1.配置分页插件 把分页的插件也配置到统一的配置类里: @Configuration // 配置扫描mapper的路径 @Map ...

  2. java IO 模型--快速分清 同步|阻塞

    IO 介绍 IO 模型 IO请求 分为两个阶段:等待资源 和 使用资源: IO请求:一般需要请求特殊资源(如 磁盘.RAM 或文件),当资源被上一个使用者使用没有释放的时候, IO请求会被阻塞,直到资 ...

  3. SpringBoot+Vue 前后端合并部署

    前后端分离开发项目 前端vue项目 服务端springboot项目 如何将vue的静态资源整合到springboot项目里,通过启动jar包的方式部署服务. 前端项目执行npm run build 命 ...

  4. [LeetCode]367. Valid Perfect Square判断完全平方数

    方法有很多,我觉得比较容易记住的是两个,一个是二分法,在1-num/2中寻找目标数 另一个是数学方法: public boolean isPerfectSquare(int num) { /* 有很多 ...

  5. 基于Opencv的简单图像处理

    实验环境 本实验均在笔记本电脑完成,电脑的配置如表1所示: 系统 Windows 10 家庭版 处理器 英特尔 Core i5-6200 @ 2.30GHz 双核 主板 宏碁 Zoro_SL 内存 1 ...

  6. React 入门-写个 TodoList 实例

    React 是一个用于构建用户界面的 JavaScript 库,主要特点有: 声明式渲染:设计好数据和视图的关系,数据变化 React 自动渲染,不必亲自操作DOM 组件化:页面切分成多个小部件,通过 ...

  7. 2020DevOps状态报告

    这是Puppet报告的走过的第九个年头,本次报告基于对2400名IT.开发.信息安全行业的技术人员的调研,着重勾画了DevOps状态的两大趋势:平台模型.需求变更的管理.多年来,我们已经证明了DevO ...

  8. windows使用sdelete安全的删除文件

    SDelete是一款来自于微软Sysinternals[1]的应用.使用SDelete可以安全的删除现有文件,以及安全地擦除磁盘的未分配部分中存在的数据(包括已经删除或加密的文件).SDelete使用 ...

  9. sqlite嵌入式数据库简介及特性

    p.p1 { margin: 0; font: 12px "Helvetica Neue"; color: rgba(69, 69, 69, 1) } p.p2 { margin: ...

  10. 各个JDK版本新语法糖

    java5语法扩充 自动装箱.泛型.动态注解.枚举.可变长参数.循环遍历等语法 JDK7 fork/join jdk8  二进制数的原生支持.switch语句中支持string <>操作符 ...