for xml path 就是将 sql 查询出来的内容以XML的格式显示出来。参考网站MSDN:将 PATH 模式与 FOR XML 一起使用

先创建测试用的表格:

  create  table SZQCSBJ
(
省 varchar(100),
市 varchar(100),
县 varchar(100)
);
insert into SZQCSBJ values('山东' ,'潍坊' ,'安丘' );
insert into SZQCSBJ values('山东' ,'潍坊','寿光' );
insert into SZQCSBJ values('山东','济南','长清' );
insert into SZQCSBJ values('广东','深圳','深圳1');
insert into SZQCSBJ values('广东','深圳','深圳2');
insert into SZQCSBJ values( '江苏','苏州','苏州1');
insert into SZQCSBJ values('江苏','苏州','苏州2');

建表并插入数据

1、默认格式

  首先直接执行如下sql:

select * from SZQCSBJ for xml path

生成格式如下:

<row>    --第一行

<列1名称>列1内容</列1名称>  --第一列

<列2名称>列2内容</列2名称>

……

</row>

<row>    --第二行

<列1名称>列1内容</列1名称>  --第一列

<列2名称>列2内容</列2名称>

……

</row>

结果如图:

格式如下:

2、常数,即没有列名,不是从表中查出来的数据的显示格式。

select 1+1 ,2+2 for xml path

结果如下:

可见,当没有列名的时候,就直接省略了列的节点,导致两列连在了一块,成为了一个节点的内容。

3、为行节点指定名称,替换掉默认的row,只需要为path 传递一个参数

select 1+1 ,2+2 for xml path('常量测试')

4、为列指定名称:为列起一个别名

select 1+1 as '列1' ,2+2 as '列2' for xml path('常量测试')

结果如下:

5、行转列,以上面的表格为例。

select 市,left(所辖县,LEN(所辖县)-1)所辖县 from
(
select 市,(
select 县+'、' from SZQCSBJ where 市=A.市 for XML path('')
)所辖县
from SZQCSBJ A
group by 市
)B

结果如图:

  

说明:

  首先执行子查询:select 县+'、' from  SZQCSBJ where 市=A.市 for XML path('')

  利用外部查询传递的 列 市 的数据,将该市的所有县查询出来,由于 县+'、' 并不是直接从表中查询来的,并且没有起一个列名,所以就没有列相关的节点名。同时将行节点命名为空字符'',所以也没有行节点,得到结果 '长清、',在后续的处理中将最后一个 '、' 字符去掉,就实现了行转列的目的

SqlServer——for xml path的更多相关文章

  1. sqlserver - FOR XML PATH

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

  2. sqlserver -- 学习笔记(八)体验charindex、stuff 和 for xml path在实际问题中的应用及几个问题的探讨

    写在前面 之前做了个微信端顾客扫码评价员工的功能,除了打分数,还可以打标签. 需要统计分数和统计各个员工每种标签被点击的次数. 后来加了个要求,需要查看客户对某个员工一次服务所打出的标签组合.  在不 ...

  3. SQLSERVER利用FOR XML PATH实现分组拼接字符串

    首先看一下数据结构表 IF(OBJECT_ID('tempdb..#tProduct')IS NOT NULL) DROP TABLE #tProduct SELECT * INTO #tProduc ...

  4. SQLServer中sql for xml path 的用法

    我们通常需要获取一个多行的某个字段拼出的字符串,我们可以使用for xml path进行处理:下面将介绍for xml path的具体用法: 创建测试表&插入测试数据 在数据库中新增测试表 C ...

  5. SqlServer 中 for xml path 相关

    表结构: typename varchar(50) typedesc varchar(50) 示例 SQL 语句: SELECT '{"'+TypeName, '":"' ...

  6. SQLServer中的cross apply和FOR XML PATH

    参考: FOR XML PATH:http://www.cnblogs.com/doubleliang/archive/2011/07/06/2098775.html cross apply:http ...

  7. sqlserver中 多条数据合并成一条数据 (stuff 与 for xml path 连用)

    SQL 列转行,即多行合并成一条   需求:按照分组,将多条记录内容合并成一条,效果如下: 数据库示例: CREATE TABLE [t2]([NID] [bigint] NULL,[district ...

  8. 问题:sqlserver有没有类似Oracle的LISTAGG;结果: 灵活运用 SQL SERVER FOR XML PATH

    灵活运用 SQL SERVER FOR XML PATH FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前 ...

  9. 多列转1列 SqlServer 实现oracle10g的 wmsys.wm_concat()--for xml path('')

    有这么一个表 )) , 'aa') , 'bb') , 'aaa') , 'bbb') , 'ccc') , 'ddd') , 'fff')                               ...

随机推荐

  1. python匿名函数 与 内置函数

      一.匿名函数  1.定义: 匿名函数顾名思义就是指:是指一类无需定义标识符(函数名)的函数或子程序. 2.语法格式:lambda 参数:表达式 lambda语句中,开头先写关键字lambda,冒号 ...

  2. Centos6.8 Jetty 安装配置

    ssh root@IP Password------------------------------------------------------------------------------↑登 ...

  3. spring 多数据源动态切换

    理解spring动态切换数据源,需要对spring具有一定的了解 工作中经常遇到读写分离,数据源切换的问题,那么以下是本作者实际工作中编写的代码  与大家分享一下! 1.定义注解 DataSource ...

  4. javaScript-条件语句优化

    1.多重判断时使用 Array.includes test = (fruit: string) => { if (fruit == 'apple' || fruit == 'strawberry ...

  5. DRF 权限的流程

    DRF 权限的流程 django rest framework,入口是 dispatch,然后依次 --->>封装请求--->>处理版本--->>>认证--- ...

  6. VS 2010 转到COFF期间失败。

    可能的原因是framework 版本不匹配,我卸载4.5,装4.0后就解决了

  7. 【MFC】MFC DLEdit 设计属于自己的编辑框_鼠标悬停

    MFC DLEdit 设计属于自己的编辑框 2012-02-04 13:00 by 捣乱小子, 3543 阅读, 5 评论, 收藏, 编辑 起因 无意间看到了大牛们写的自定义编辑框控件,于是找了个时间 ...

  8. BigDecimal的用法

    一.简介 Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算.双精度浮点型变量double可以处理16位有效数.在实际应用中,需要对更大或者更 ...

  9. 【操作系统】总结五(I/O管理)

    输入输出管理本章主要内容: I/O管理概述(I/O控制方式.I/O软件层次结构)和I/O核心子系统(I/O调度概念.局速缓存与缓冲区.设备分配与回收.假脱机技术(SPOOLing)). 5.1 I/O ...

  10. computed属性与methods、watched

    一.计算属性 new Vue({ data: { message: 'hello vue.js !' }, computed: { reverseMessage: function () { retu ...