详解SQL中FORXML子句的各种用法

FOR XML子句有四种最基本的模式,如上图所示:

专注于为中小企业提供成都网站制作、网站设计、外贸网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业汉南免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

1、AUTO模式:返回数据表为起表名的元素,每一列的值返回为属性;

2、RAW模式:返回数据行为 元素,每一列的值作为 元素的属性;

3、PATH模式:通过简单的XPath语法来允许用户自定义嵌套的XML结构、元素、属性值

4、EXPLICIT模式:通过SELECT语法定义输出XML的结构

具体实例如下:

1、AUTO模式

(1). SQL语句:

   1:  SELECT EmployeeID,FirstName,LastName FROM Employees FOR XML AUTO, XMLSCHEMA

(2). 所生成的XML文件:

返回XML文件的XML Schema


  
  
    
      
      
        
          
            
           xsd:restriction>
         xsd:simpleType>
       xsd:attribute>
      
        
          
            
           xsd:restriction>
         xsd:simpleType>
       xsd:attribute>
     xsd:complexType>
   xsd:element>
xsd:schema>









2、RAW模式

1:  ----将元素命名为自定义的名称Employee
2:  SELECT EmployeeID,FirstName,LastName FROM Employees FOR XML RAW ('Employee') 
(2). 所生成的XML文件:   
1:     
2:     
3:     
4:     
5:     
6:     
7:     
8:     
9:  

3、PATH模式:

(1). SQL语句:

SELECT EmployeeID "@ID",FirstName  "Name/FirstName",LastName "Name/LastName"
FROM Employees FOR XML PATH ('Employee')

(2). 所生成的XML文件


  
    Nancy FirstName>
    Davolio LastName>
   Name>
Employee>

  
    Andrew FirstName>
    Fuller LastName>
   Name>
Employee>

  
    Janet FirstName>
    Leverling LastName>
   Name>
Employee>

  
    Margaret FirstName>
    Peacock LastName>
   Name>
Employee>

  
    Steven FirstName>
    Buchanan LastName>
   Name>
Employee>

  
    Michael FirstName>
    Suyama LastName>
   Name>
Employee>

  
    Robert FirstName>
    King LastName>
   Name>
Employee>

  
    Laura FirstName>
    Callahan LastName>
   Name>
Employee>

4、EXPLICIT模式

问题:加入要生成如下的XML文档该如何操作?

Nancy Davolio EXPLICIT模式解决这个问题的应用分为两个主要步骤

1.定义要输出的XML文档结构;

2.传入实际的数据值;

(1). SQL语句:

 
 
 
 
--定义输出XML文档的数据结构SELECT  1 AS Tag,
        NULL AS Parent,
        EmployeeID AS [Employee!1!EmpID],
        FirstName AS [Employee!1!FirstName!element],
        LastName AS [Employee!1!LastName!element]FROM
    Employees UNION ALL--传入实际的数据SELECT  1, NULL, 
       EmployeeID,        FirstName, 
       LastNameFROM    EmployeesORDER BY [Employee!1!EmpID],
[Employee!1!FirstName!element],        [Employee!1!LastName!element]
FOR     XML EXPLICIT

语句含义的解释:

先看看定义XML结构的语句输出结果:

Tag栏用来指定生成元素的嵌套水平;1表示嵌套水平为

Parent栏用来指定当前Tag的父级层次;Null值表示该元素为***元素;

EmployeeID AS [Employee!1!EmpID],

说明:当前元素或属性的父级元素的名称!元素的标签号!元素或属性的名称
FirstName AS [Employee!1!FirstName!element],

说明:当前元素或属性的父级元素的名称!元素的标签号!元素或属性的名称!指定值作为元素输出

5、为输出的XML文档添加根元素(Root element)

(1). SQL语句:

SELECT EmployeeID,FirstName,LastName FROM Employees FOR XML AUTO, ROOT('MyRoot')

(2). 所生成的XML文件


  
  
  
  
  
  
  
  
  
MyRoot>

当前文章:详解SQL中FORXML子句的各种用法
分享路径:http://www.mswzjz.cn/qtweb/news19/81069.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能