通过SQL语句直接把表导出为XML格式

所属分类: 数据库 / MsSql 阅读数: 1709
收藏 0 赞 0 分享
首先建立一张表:

复制代码 代码如下:

USE [ip]
GO
/****** 对象: Table [dbo].[SiteData] 脚本日期: 09/11/2010 17:41:11 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[SiteData](
[id] [int] IDENTITY(1,1) NOT NULL,
[SiteName] [varchar](50) COLLATE Chinese_PRC_CI_AS NOT NULL,
[SiteAdd] [varchar](100) COLLATE Chinese_PRC_CI_AS NOT NULL,
[BaiduSort] [int] NOT NULL CONSTRAINT [DF_SiteData_BaiduSort] DEFAULT ((0)),
[BaiduShouLu] [int] NOT NULL CONSTRAINT [DF_SiteData_BaiduShouLu] DEFAULT ((0)),
CONSTRAINT [PK_SiteData] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (PAD_INDEX = OFF, IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]

GO
SET ANSI_PADDING OFF

表中数据如下:

 表中数据

表中字段分别为:编号、网站名称、网站地址、百度排名、百度收录。

现在我们就把这张表直接导出为XML格式,SQL语句如下:

复制代码 代码如下:

SELECT
1 AS Tag,
NULL AS Parent,
SiteName AS [site!1!网站名称],
SiteAdd AS [site!1!网站地址],
BaiduSort AS [site!1!百度排名],
BaiduShouLu AS [site!1!百度收录]
FROM SiteData order by BaiduShouLu FOR XML EXPLICIT

运行这条语句之后,我们在SQL Server2005的运行结果里可以看到如下内容:

导出结果

我们可以看到,这个XML的节点的内容我们是可以在SQL与距离进行自定义的,这个时候只要我们点击一下这个输出结果,就能导出XML格式的一段代码了。

我们将会得到:

复制代码 代码如下:

<site 网站名称="博客园" 网站地址="https://www.jb51.net/" 百度排名="20" 百度收录="6020000" />

我们现在得到的这个XML代码是不包含XML的表头以及编码格式的,如果我们想做的更傻瓜化一些可以直接在后台自定义添加以下内容:
复制代码 代码如下:

//content 是我们读取数据库后得到的string字符串
content = content.Replace("&lt;", "<").Replace("&quot;", "\"").Replace("&gt;", ">");
//自定义XML编码格式和父节点名称
content = "<?xml version=\"1.0\" encoding=\"utf-8\"?><start>" + content + "</start>
//输出XML到本地路径using
(StreamWriter sw = new StreamWriter(@"E:\SoftUpdate\sql2xml.xml")) { sw.Write(content); }

更多精彩内容其他人还在看

浅析SQL Server 聚焦索引对非聚集索引的影响

本篇文章对SQL Server的聚焦索引和非聚集索引进行简单分析,从而总结出聚焦索引对非聚集索引的影响。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅析SQL Server的聚焦使用索引和查询执行计划

本文通过介绍默认使用索引、强制使用聚集索引、强制使用非聚集索引让我们知道对于检索所有列结果集使用主键的聚集索引是最佳选择。有兴趣的朋友可以看下
收藏 0 赞 0 分享

详解SQL Server中的数据类型

本文主要讲解了SQL中的数据类型以及几个需要注意的地方,简短的内容,深入的理解。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅析SQL Server的分页方式 ISNULL与COALESCE性能比较

本文上述重点讲述了SQL Server的分页方式,COALESCE和ISNULL函数区别之处,简短的内容,深入的理解。有兴趣的朋友可以看下
收藏 0 赞 0 分享

浅述SQL Server的聚焦强制索引查询条件和Columnstore Index

本文主要讲了强制使用索引条件来进行查询,当对于使用默认创建索引进行查询计划时觉得不是最优解,可以尝试使用强制索引来进行对比找出更好得解决方案。简短的内容,深入的理解.有兴趣的朋友可以看下
收藏 0 赞 0 分享

详解SQL Server的聚焦过滤索引

本文主要讲解了通过过滤索引来提高查询性能,同时也给出了其不同的场景以及其使用优点和明显的缺点。简短的内容,深入的理解,有兴趣的朋友可以看下
收藏 0 赞 0 分享

解析SQL Server聚焦移除(Bookmark Lookup、RID Lookup、Key Lookup)

本文主要讲解索引性能优化,着重对Bookmark Lookup、RID Lookup、Key Lookup三者进行移除的实现进行解析,以此来提高查询性能。希望对大家有所帮助
收藏 0 赞 0 分享

SqlServer 注释符 单行注释与多行注释

这篇文章主要介绍了SqlServer 注释符 单行注释与多行注释,需要的朋友可以参考下
收藏 0 赞 0 分享

SQL设置SQL Server最大连接数及查询语句

今天遇到了关于Sql Server最大连接数(Max Pool Size)的问题,后来通过查找一些资料解决了,所以想着总结下关于SQL Server最大连接数的内容,所以这篇文章主要介绍了SQL设置SQL Server最大连接数与查询语句,有需要的朋友们可以参考借鉴。
收藏 0 赞 0 分享

浅谈SQL Server交叉联接 内部联接

本文主要讲了SQL Server的交叉联接和内部联接,同时也给出了使用需要注意的地方。有需要的朋友可以看下
收藏 0 赞 0 分享
查看更多