SQL Server中将数据导出为XML和Json方法分享
有时候需要一次性将SQL Server中的数据导出给其他部门的也许进行关联或分析,这种需求对于SSIS来说当然是非常简单,但很多时候仅仅需要一次性导出这些数据而建立一个SSIS包就显得小题大做,而SQL Server的导入导出工具其中BUG还是蛮多的,最简单的办法是BCP。
数据导出为XML
在SQL Server 2005之后提供了一个for xml子句在关系数据库中原生支持XML。通过该命令可以将二维关系结果集转换为XML,通过BCP就可以将数据存为XML了。
例如下面的数据:
我们可以通过如下BCP命令(注意不能有回车)将其导出为XML文件,并保存:
BCP "SELECT TOP 30 [bom_no],[LEVEL] FROM [sqladmin].[dbo].[bom] FOR XML path,TYPE, ELEMENTS ,ROOT('RegionSales')" QUERYOUT "d:\temp\test.XML" -c -t -T -S localhost
执行完成后查看Test.XML文件,如下图所示。可以看到文件格式非常清晰,很容易就可以导入到其他系统了。
数据导出为JSON
如果希望将SQL Server中数据导出为Json,虽然这种操作在应用程序里已经有非常成熟的方法,但SQL Server其实并没有原生支持这种方式(小道消息,下个版本会支持)。我推荐使用这篇帖子的方式:https://www.jb51.net/article/61462.htm来做。将该帖子所提供的存储过程建立完成后,使用如下BCP命令:
执行完成后,得到结果如下图:
相关文章
SQLserver2000 企业版 出现"进程51发生了严重的异常"错误的处理方法
SQL2000 企业版 出现“进程51发生了严重的异常”错误的解决方法,利用了微软官方的工具。2009-07-07
SQL Server 2012 搭建数据库AlwaysOn(数据库高可用集群)
这篇文章主要介绍了SQL Server 2012 搭建数据库AlwaysOn(数据库高可用集群),需要的朋友可以参考下2023-05-05
SQL Server 2000/2005/2008删除或压缩数据库日志的方法
最近win2008 r2的服务器比较卡,打开服务器显示也特别慢,sqlserver业务费正常执行,服务器桌面操作也比较卡,经过多方研究发现原来是sqlserver日志文件已经达到了84G导致,这里就为大家分享一下解决方法,需要的朋友可以参考一下2019-09-09
sqlserver清空service broker中的队列的语句分享
在我们开发service broker应用时候,可能用于测试或者客户端没有配置正确等导致服务端队列存在很多垃圾队列,不便于我们排查错误,我们可以使用SQL脚本来清空服务端这些垃圾数据2011-08-08
SQL Server 不删除信息重新恢复自动编号列的序号的方法
SQL Server 不删除信息重新恢复自动编号列的序号的方法...2007-11-11







最新评论