SQL SERVER 2008取出XML数据

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 用SQL SERVER 2008的for xml可以读取数据并转为XML,下面例程使用了pubs数据库 DECLARE @idoc int DECLARE @doc varchar(1000) set @doc=' 172-32-1176 ...

用SQL SERVER 2008的for xml可以读取数据并转为XML,下面例程使用了pubs数据库

DECLARE @idoc int
DECLARE @doc varchar(1000) 
set @doc='
  <ROOT>
    <authors>
        <au_id>172-32-1176</au_id>
        <au_lname>White</au_lname>
        <au_fname>Johnson</au_fname>
        <phone>408 496-7223</phone>
        <address>1010932 Bigger Rd.</address>
        <city>Menlo Park</city>
        <state>CA</state>
        <zip>94025</zip>
        <contract>1</contract>
        <books>
            <title>My Book1</title>
            <title>My Book2</title>
        </books>
    </authors>
    <authors>
        <au_id>213-46-8915</au_id>
        <au_lname>Green</au_lname>
        <au_fname>Marjorie</au_fname>
        <phone>415 986-7020</phone>
        <address>309 St. #31</address>
        <city>Boston</city>
        <state>CA</state>
        <zip>94618</zip>

        <contract>1</contract>
        <books>
            <title>My Book3</title>
            <title>My Book4</title>
        </books>
    </authors>
</ROOT>    '

exec sp_xml_preparedocument @idoc OUTPUT,@doc

select a.title,a.au_lname,p.pub_name,p.city
 from  openxml(@idoc,'/ROOT/authors/books',2) 
        WITH(title  varchar(20) './title',
             au_id  varchar(11) '../au_id',
             au_lname varchar(40) '../au_lname',
             au_fname varchar(20) '../au_fname',
             phone varchar(12) '../phone',
             city varchar(20) '../city') As a 
 inner join publishers as p  
   ON a.city=p.city             
   
use pubs
go
select * from authors for xml raw   

select * from authors for xml auto

select publishers.pub_name,titles.title,titles.price 
  from titles,publishers where publishers.pub_id=titles.pub_id
  for xml auto


select 1 As Tag,null as parent,
  authors.au_fname as [Authors!1!au_fname!element],
  authors.au_lname as [Authors!1!au_lname!element],
  NULL AS [Titleauthor!2!Royaltyper],
  NULL AS [Titles!3!au_fname!element]  
FROM  
  authors
UNION ALL
select 2 As Tag,1 as parent,
  au_fname,au_lname,royaltyper,NULL 
from authors inner join titleauthor on 
authors.au_id=titleauthor.au_id  

union all    
select 3 As Tag,2 as parent,
  au_fname,au_lname,royaltyper,title  
from authors inner join titleauthor on 
authors.au_id=titleauthor.au_id inner join titles on 
titles.title_id=titleauthor.title_id   
order by [Authors!1!au_fname!element],[Authors!1!au_lname!element],
   [Titleauthor!2!Royaltyper],tag 
for xml explicit   
             

 

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
1月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
2月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
2月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
2月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
2月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
411 4
|
2月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
104 0
|
2月前
|
SQL 分布式计算 关系型数据库
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
48 0
|
2月前
|
SQL 分布式计算 关系型数据库
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
57 0
|
2月前
|
XML Web App开发 数据格式
HTML 页面显示 XML 数据
10月更文挑战第2天
|
2月前
|
SQL
使用SQL进行集合查询和数据维护
使用SQL进行集合查询和数据维护
45 0
下一篇
DataWorks