0

0

FOR XML之RAW模式的代码实例详解

黄舟

黄舟

发布时间:2017-03-22 17:03:13

|

2417人浏览过

|

来源于php中文网

原创

描述:

raw模式将查询结果集中的每一行转换为带有元素名称的xml元素,将每一行的列转换为row的属性.可以通过编写嵌套FOR XML查询来生成XML层次结构在默认情况下,所有非null值都将被映射为元素的属性.如果需要将查询结果集中数据转换为元素的子元素,需要使用elements指令.

语法:

FOR XML
RAW [ ('ElementName') ] 
    [ 
        
       [ , { XMLDATA | XMLSCHEMA [ ('TargetNameSpaceURI') ]} ] 
       [ , ELEMENTS [ XSINIL | ABSENT ] 
    ]  ::= 
   [ , BINARY BASE64 ]
   [ , TYPE ]
   [ , ROOT [ ('RootName') ] ]

具体参见例子:

建表Base,表结构如下:

列名 数据类型 允许空
id int 允许
body nvarchar(50) 允许

插入表数据如下:

id body
1 aaaa
2 bbbb
3 cccc
4  

例句:

A.返回查询数据的信息,使用for xml raw 模式

/*
结果:
    
    
    
    
*/select * from base for xml raw;

通过指定ELEMENTS指令使结果集以子元素的形式出现.

/*
结果:
    
      1
      aaaa
    
    
      2
      bbbb
    
    
      3
      dddd
    
    
      4
    
*/select * from base for xml raw,elements;

我们注意到这个例句中没有将id为4的body显示出现.

原因是因为,在使用elements指令时,如果没有指定后面的命令,则默认使用abscent,此时不会为null值创建任何元素.

在下面的例句中通过使用elements xsinil可使null值显示在xml中.

B.同时指定elements指令和xsinil指令以生产null列值的元素

/*
结果:
    
      1
      aaaa
    
    
      2
      bbbb
    
    
      3
      dddd
    
    
      4
      
    
*/select * from base for xml raw,elements xsinil;

对于每条数据都是以元素显示会让人看起来很不舒服,如何修改元素名称为其他名称呢.

C.重命名元素

/*
结果:
    
      1
      aaaa
    
    
      2
      bbbb
    
    
      3
      dddd
    
    
      4
      
    
*/select * from base for xml raw('baseinfo'),elements xsinil;

我们都知道,每个xml文件都有一个根元素,我们如何为这段xml文本加上它的根元素呢.

D.为for xml生成的xml指定根元素

可使用root指定,root指令的默认根元素为

/*
结果:
    
      
        1
        aaaa
      
      
        2
        bbbb
      
      
        3
        dddd
      
      
        4
        
      
    
*/select * from base for xml raw('baseinfo'),root('base'),elements xsinil;

目前看起来,生成的xml结果似乎很不错,但是,如果我们想要将数据库中的body列改成xml的元素,该如何修改呢?

E.修改元素名

快剪辑
快剪辑

国内⼀体化视频⽣产平台

下载
/*
结果:
    
      
        1
        aaaa
      
      
        2
        bbbb
      
      
        3
        dddd
      
      
        4
        
      
    
*/select id,body data from base for xml raw('baseinfo'),root('base'),elements xsinil;

现在的结果,基本上符合一个xml的基本格式,那么,我们设想,如果不给id,body指定列名,也不指定根元素名,也不指定元素名,那会出现什么记过呢?

/*
结果:
    1aaaa2bbbb3dddd4
*/
--因为id为int类型,为使id不出现列名,我们使id+0
--因为body为nvarchar类型,为使body不出现列名,我们使body+''select id+0,body+'' from base for xml raw(''), elements;

但是,对上面的结果,我们似乎无法分清楚每条数据,而且id为4的空值也没有显示出来,如何进行修改呢?见下句.

/*
结果:
    1,aaaa;2,bbbb;3,dddd;4,null;
*/select id+0,',',isnull(body,'null')+'',';' from base for xml raw(''),elements;

如此以来,似乎看到了没有列名给我们带的好处.其实上句还可以再修改些.

/*
结果:
    1,aaaa;2,bbbb;3,dddd;4,null;
*/select convert(nvarchar,id)+','+isnull(body,'null')+';' from base for xml raw(''),elements;

我们再来修改,让让结果以另一种方式出现.

/*
结果:
    {1,aaaa}{2,bbbb}{3,dddd}{4,null}
*/select '{'+convert(nvarchar,id)+','+isnull(body,'null')+'}' from base for xml raw(''),elements;

现在可以看到,我们可以根据自己的需要进行组合,生成我们需要的结果.

在SQLServer2005中,已经支持了xml数据类型,因此,可以通过编写TYPE指令,将FOR XML查询的结果以xml数据类型进行返回,举例如下:

declare @string nvarchar(1000)declare @xml xml/*
    消息257,级别16,状态3,第8行
    不允许从数据类型xml到nvarchar的隐式转换。请使用CONVERT函数来运行此查询。
*/
--set @string=(select id,body from base for xml raw,type)set @xml=(select id,body from base for xml raw,type)

最后,以一个常用的例子来介绍for xml raw模式的应用.

建学生表student,表结构如下:

列名 数据类型 允许空
sid int 允许
name nvarchar(50) 允许

插入表数据如下:

id name
1 张三
2 李四
3 王五

建课程表sclass,表结构如下:

列名 数据类型 允许空
cid int 允许
name nvarchar(50) 允许

插入表数据如下:

id name
1 语文
2 数学
3 英语

建student_class表,表结构如下:

列名 数据类型 允许空
sid int  
cid int  

插入数据如下:

cid sid
1 1
1 2
1 3
2 1
3 2
3 3

至此,数据结果是:

姓名 课程
张三 语文
张三 数学
张三 英语
李四 语文
王五 数学
王五 英语

我们需要最后的结果形式如下:

姓名 课程
张三 语文,数学,英语
李四 语文
王五 数学,英语

该如何实现呢?

/*
结果:
    张三    语文,数学,英语
    李四    语文
    王五    数学,英语
*/select [name],            
stuff(
(                    
select ','+[name]                    
from sclass                    
where cid in (                                    
select cid                                    
from student_class                                    
where student.sid=student_class.sid                                
)                    
for xml raw(''),elements                
),            
1,1,'') sclassfrom student

相关专题

更多
C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

9

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

14

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

42

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

6

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

9

2026.01.15

ppt一键生成相关合集
ppt一键生成相关合集

本专题整合了ppt一键生成相关教程汇总,阅读专题下面的的文章了解更多详细内容。

6

2026.01.15

php图片上传教程汇总
php图片上传教程汇总

本专题整合了php图片上传相关教程,阅读专题下面的文章了解更多详细教程。

2

2026.01.15

phpstorm相关教程大全
phpstorm相关教程大全

本专题整合了phpstorm相关教程汇总,阅读专题下面的文章了解更多详细内容。

4

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP基础入门课程
PHP基础入门课程

共33课时 | 1.9万人学习

前端系列快速入门课程
前端系列快速入门课程

共4课时 | 0.4万人学习

XML教程
XML教程

共142课时 | 5.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号