欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

在SQL Server中将数据导出为XML和Json的方法

程序员文章站 2023-11-25 15:13:34
    有时候需要一次性将sql server中的数据导出给其他部门的也许进行关联或分析,这种需求对于ssis来说当然是非常简单,但很多时候仅...

    有时候需要一次性将sql server中的数据导出给其他部门的也许进行关联或分析,这种需求对于ssis来说当然是非常简单,但很多时候仅仅需要一次性导出这些数据而建立一个ssis包就显得小题大做,而sql server的导入导出工具其中bug还是蛮多的,最简单的办法是bcp。

 

数据导出为xml

    在sql server 2005之后提供了一个for xml子句在关系数据库中原生支持xml。通过该命令可以将二维关系结果集转换为xml,通过bcp就可以将数据存为xml了。

    例如下面的数据:

在SQL Server中将数据导出为XML和Json的方法

 

    我们可以通过如下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

 

    在SQL Server中将数据导出为XML和Json的方法

 

    执行完成后查看test.xml文件,如下图所示。可以看到文件格式非常清晰,很容易就可以导入到其他系统了。

在SQL Server中将数据导出为XML和Json的方法

 

数据导出为json

 

   如果希望将sql server中数据导出为json,虽然这种操作在应用程序里已经有非常成熟的方法,但sql server其实并没有原生支持这种方式(小道消息,下个版本会支持)。我推荐使用这篇帖子的方式:http://jaminquimby.com/servers/95-sql/sql-2008/145-code-tsql-convert-query-to-json来做。将该帖子所提供的存储过程建立完成后,使用如下bcp命令:

在SQL Server中将数据导出为XML和Json的方法

 

    执行完成后,得到结果如下图:

在SQL Server中将数据导出为XML和Json的方法