数据库 
首页 > 数据库 > 浏览文章

SQL Server中将数据导出为XML和Json方法分享

(编辑:jimmy 日期: 2024/11/9 浏览:3 次 )

    有时候需要一次性将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其实并没有原生支持这种方式(小道消息,下个版本会支持)。我推荐使用这篇帖子的方式:https://www.jb51.net/article/61462.htm来做。将该帖子所提供的存储过程建立完成后,使用如下BCP命令:

SQL Server中将数据导出为XML和Json方法分享

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

SQL Server中将数据导出为XML和Json方法分享

上一篇:SQL Server存储过程中使用表值作为输入参数示例
下一篇:sqlserver中存储过程的递归调用示例
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。