`

灵活运用 SQL SERVER FOR XML PATH

阅读更多
转载地址:http://www.cnblogs.com/doubleliang/archive/2011/07/06/2098775.html
FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作。那么以一个实例为主.

        一.FOR XML PATH 简单介绍

             那么还是首先来介绍一下FOR XML PATH ,假设现在有一张兴趣爱好表(hobby)用来存放兴趣爱好,表结构如下:

       接下来我们来看应用FOR XML PATH的查询结果语句如下:

SELECT * FROM @hobby FOR XML PATH       结果:


<row>
  <hobbyID>1</hobbyID>
  <hName>爬山</hName>
</row>
<row>
  <hobbyID>2</hobbyID>
  <hName>游泳</hName>
</row>
<row>
  <hobbyID>3</hobbyID>
  <hName>美食</hName>
</row>
      由此可见FOR XML PATH 可以将查询结果根据行输出成XML各式!

      那么,如何改变XML行节点的名称呢?代码如下:     

SELECT * FROM @hobby FOR XML PATH('MyHobby')

      结果一定也可想而知了吧?没错原来的行节点<row> 变成了我们在PATH后面括号()中,自定义的名称<MyHobby>,结果如下:


<MyHobby>
  <hobbyID>1</hobbyID>
  <hName>爬山</hName>
</MyHobby>
<MyHobby>
  <hobbyID>2</hobbyID>
  <hName>游泳</hName>
</MyHobby>
<MyHobby>
  <hobbyID>3</hobbyID>
  <hName>美食</hName>
</MyHobby>
      这个时候细心的朋友一定又会问那么列节点如何改变呢?还记的给列起别名的关键字AS吗?对了就是用它!代码如下:

SELECT hobbyID as 'MyCode',hName as 'MyName' FROM @hobby FOR XML PATH('MyHobby')

      那么这个时候我们列的节点名称也会编程我们自定义的名称 <MyCode>与<MyName>结果如下:

<MyHobby>
  <MyCode>1</MyCode>
  <MyName>爬山</MyName>
</MyHobby>
<MyHobby>
  <MyCode>2</MyCode>
  <MyName>游泳</MyName>
</MyHobby>
<MyHobby>
  <MyCode>3</MyCode>
  <MyName>美食</MyName>
</MyHobby>
    噢! 既然行的节点与列的节点我们都可以自定义,我们是否可以构建我们喜欢的输出方式呢?还是看代码: 
SELECT '[ '+hName+' ]' FROM @hobby FOR XML PATH('')    没错我们还可以通过符号+号,来对字符串类型字段的输出格式进行定义。结果如下:

[ 爬山 ][ 游泳 ][ 美食 ]    那么其他类型的列怎么自定义? 没关系,我们将它们转换成字符串类型就行啦!例如:

SELECT '{'+STR(hobbyID)+'}','[ '+hName+' ]' FROM @hobby FOR XML PATH('')    好的 FOR XML PATH就基本介绍到这里吧,更多关于FOR XML的知识请查阅帮助文档!

    接下来我们来看一个FOR XML PATH的应用场景吧!那么开始吧。。。。。。

        二.一个应用场景与FOR XML PATH应用

        首先呢!我们在增加一张学生表,列分别为(stuID,sName,hobby),stuID代表学生编号,sName代表学生姓名,hobby列存学生的爱好!那么现在表结构如下:

          

        这时,我们的要求是查询学生表,显示所有学生的爱好的结果集,代码如下:


SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby FROM (
SELECT sName,
(SELECT hobby+',' FROM student
  WHERE sName=A.sName
  FOR XML PATH('')) AS StuList
FROM student A
GROUP BY sName
) B
         结果如下:

分析: 好的,那么我们来分析一下,首先看这句:

SELECT hobby+',' FROM student
  WHERE sName=A.sName
  FOR XML PATH('')这句是通过FOR XML PATH 将某一姓名如张三的爱好,显示成格式为:“ 爱好1,爱好2,爱好3,”的格式!

那么接着看:


SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby FROM (
SELECT sName,
(SELECT hobby+',' FROM student
  WHERE sName=A.sName
  FOR XML PATH('')) AS StuList
FROM student A
GROUP BY sName
) B 
剩下的代码首先是将表分组,在执行FOR XML PATH 格式化,这时当还没有执行最外层的SELECT时查询出的结构为:



可以看到StuList列里面的数据都会多出一个逗号,这时随外层的语句:SELECT B.sName,LEFT(StuList,LEN(StuList)-1) as hobby  就是来去掉逗号,并赋予有意义的列明!

分享到:
评论

相关推荐

    SQL Server FOR XML PATH 语句的应用

    通过上述示例可以看出,`FOR XML PATH`语句在SQL Server中是非常强大的工具,可以灵活地生成各种结构的XML数据。无论是简单的表格数据还是复杂的分组结构,都能够通过调整参数和使用嵌套查询来实现。这对于需要与...

    sqlserver FOR XML PATH 语句的应用

    `FOR XML PATH` 是 SQL Server 中用于构造 XML 数据的一个强大工具。通过这个语句,你可以将 SQL 查询结果转换成 XML 格式,便于数据交换、存储或者进一步处理。以下是对 `FOR XML PATH` 语句的详细解释和应用示例。...

    FOR XML子句在SQL Server中的用法比较.pdf

    本篇文章主要介绍了SQL Server中FOR XML子句的四种不同用法:AUTO、RAW、EXPLICIT和PATH,并且通过实例对每种方式进行了分析比较。 1. RAW方式 RAW方式是将查询结果集中的每一行数据转换成一个XML元素的过程,它是...

    sqlserver to XML

    以下是对"sqlserver to XML"这个主题的详细说明: 一、XML的基本概念 XML是一种自描述的文本格式,它使用标签来定义数据结构。与HTML不同,XML设计用于存储和传输数据,而不是显示数据。XML文档包含元素、属性、...

    Sqlserver2005XML优化知识

    在SQL Server 2005中,XML字段的优化至...综上所述,理解并正确运用SQL Server 2005中的XML查询语法和索引策略,是优化XML字段性能的关键。合理设计和利用索引,能够显著提高XML数据的查询效率,降低数据库的运行成本。

    SQLServer中XML应用

    随着 SQL Server 2000 的推出,Transact-SQL 语言中新增了 `FOR XML` 和 `OPENXML` 关键字,允许开发者通过编写 Transact-SQL 代码来生成 XML 格式的查询结果或导入 XML 文档。 到了 SQL Server 2005 版本,微软...

    SQL SERVER 将XML变量转为JSON文本

    在SQL Server中,XML数据类型提供了处理XML文档的能力,而JSON是另一种广泛使用的轻量级数据交换格式。有时,我们可能需要将XML数据转换成JSON格式,以适应现代Web应用程序的需求。本文将介绍如何在SQL Server中创建...

    SQL Server 2000 XML技术及应用.pdf

    此外,SQL Server 2000还能够检索及写入XML数据,具体方法包括使用SELECT语句和FORXML子句来检索XML数据,以及使用OPENXML行集提供程序来写入XML数据。除此之外,SQL Server 2000还通过增强的OLEDB提供程序,支持将...

    SQL Server 将某一列的值拼接成字符串.docx

    首先,`FOR XML PATH('')` 是SQL Server中用于生成XML的一种方式,但在这里它被巧妙地用于字符串拼接。在提供的示例中,查询首先通过LEFT JOIN操作连接了 `_VIPHall_Link_AuxType`, `_VIPHall`, 和 `_Dim_VIPHall_...

    sqlserver驱动jar

    Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); Connection conn = DriverManager.getConnection(url, username, password); System.out.println("Connected to the database!"); // ... 执行...

    SQL_Server_2008中XML应用

    无论是简单的数据导出还是复杂的多表查询,都能通过灵活运用 `FOR XML` 子句来实现高效的数据交换。这对于那些需要在数据库和外部系统之间传递 XML 数据的应用程序来说,无疑是一个巨大的福音。

    将Sql Server数据库转换成Xml文件

    2. **使用FOR XML子句**:在Sql Server中,可以使用`FOR XML`子句将查询结果直接转换为Xml格式。例如,一个简单的查询可能如下所示: ``` SELECT * FROM YourTableName FOR XML AUTO ``` 这里的`AUTO`模式会自动...

    SqlServer GroupConcat

    在SQL Server中,我们可以用`FOR XML PATH`结合`STUFF`函数来达到类似的效果,但这通常需要更复杂的SQL语句。而`SqlServer GroupConcat`的CLR实现则提供了一个更为简洁的解决方案,使得在SQL Server中进行字符串聚合...

    sql 输出xml

    首先,我们来看下`FOR XML PATH`函数的使用,这是在SQL Server中用来将查询结果输出为XML格式的一个重要工具。通过指定`PATH`子句,你可以控制输出的XML结构。如果省略`PATH`子句,那么输出的XML将是一个单节点,...

    Win10可用的Microsoft SQL Server 2008 Native Client

    5. **支持SQL Server的新特性和改进**:包括对XML数据类型的原生支持,改进的错误处理机制,以及对大容量日志记录和快照隔离的支持。 6. **数据类型和函数的扩展**:除了基本的SQL Server数据类型,Native Client还...

    SQL Server jar驱动包

    - 加载JDBC驱动:`Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver")` - 创建数据库连接:`Connection conn = DriverManager.getConnection(url, username, password)` - 创建Statement或...

    sql server 直接读取excel

    在SQL Server中,直接读取Excel文件是一种常见的需求,特别是在数据整合、分析或者报表生成时。标题和描述中提到的方法允许我们避免将Excel数据导入到数据库中,而是直接在SQL Server中对Excel文件进行查询或处理。...

Global site tag (gtag.js) - Google Analytics