知方可补不足~SQL巧用XML PATH来生成符合规则的查询结果集

简介:

在查询后面在

FOR XML PATH可以生成XML格式结果集,好好利用这个技术,可以实现很多意想不到的查询效果

最简单的用法:

SELECT USERID,USERNAME FROM DBO.USER_INFO FOR XML PATH

结果类似这样

<row>
  <USERID>6</USERID>
  <USERNAME>ding25901</USERNAME>
</row>
<row>
  <USERID>10</USERID>
  <USERNAME>zhong</USERNAME>
</row>
<row>
  <USERID>11</USERID>
  <USERNAME>yanxunhan</USERNAME>
</row>

我们看到是以XML格式来显示的,注意它是个字符串,它只显示在一行上。

可以为path加个参数,来改变row节点的名称,如

SELECT USERID,USERNAME FROM DBO.USER_INFO FOR XML PATH('zzl')

结果变成了这样

<zzl>
  <USERID>6</USERID>
  <USERNAME>ding25901</USERNAME>
</zzl>
<zzl>
  <USERID>10</USERID>
  <USERNAME>zhong</USERNAME>
</zzl>

当然,发挥我们的想像力,可能也会出现这种结果

{6,ding25901}{10,zhong}

怎么样,有点像JSON的格式标准吧,看看代码:

SELECT TOP 2
        '{' + CAST(UserID AS VARCHAR) + ',' ,
        userName + '' ,
        '}'
FROM    dbo.User_Info
FOR     XML PATH('')

只要发挥你的想像力,就有你想不到的事情发生,如果没有xml path,可能我们还要用性能较低的游标

看看这个例子,找出用户地址表中,所有用户的所有地址信息:

SELECT  B.userid ,
        List
FROM    ( SELECT    userid ,
                    ( SELECT    c.address + ','
                      FROM      dbo.UserAddress c
                      WHERE     c.UserID = a.userid
                    FOR
                      XML PATH('')
                    ) AS List
          FROM      dbo.UserAddress A
          GROUP BY  userid
        ) B

结果是:

userid                               addresslist
------------------------------------ ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
010E3E9D-67F5-4C25-80A7-0B56D03F3427 日本,中国,
062061EB-61F2-49A3-AA87-7BD5A59F5970 中国,美国,
1A58A662-A3DF-4BEE-B0D0-B0F73846D55B 中东,

本文转自博客园张占岭(仓储大叔)的博客,原文链接:知方可补不足~SQL巧用XML PATH来生成符合规则的查询结果集,如需转载请自行联系原博主。

目录
相关文章
|
6天前
|
XML Java 数据库连接
mybatis中在xml文件中通用查询结果列如何使用
mybatis中在xml文件中通用查询结果列如何使用
8 0
|
7天前
|
SQL
sql语句加正则 简化查询
sql语句加正则 简化查询
10 0
sql语句加正则 简化查询
|
25天前
|
SQL
sql server链接查询
sql server链接查询
17 1
|
25天前
|
SQL
sql server简单查询
sql server简单查询
12 1
|
15天前
|
SQL 关系型数据库 MySQL
mysql一条sql查询出多个统计结果
mysql一条sql查询出多个统计结果
12 0
|
25天前
|
SQL
sql高级查询
sql高级查询
12 0
|
1月前
|
SQL 存储 数据可视化
10个高级的 SQL 查询技巧
10个高级的 SQL 查询技巧
|
26天前
|
SQL 数据库
sql server高级查询,看这篇文章就够了
sql server高级查询,看这篇文章就够了
20 0
|
29天前
|
SQL
T-SQL 语句查询
T-SQL 语句查询
55 0
|
30天前
|
SQL 存储 关系型数据库
sql数据库查询语句大全
sql数据库查询语句大全