您现在的位置是:网站首页> 编程资料编程资料
在SQL Server中将数据导出为XML和Json的方法_MsSql_
2023-05-26
615人已围观
简介 在SQL Server中将数据导出为XML和Json的方法_MsSql_
有时候需要一次性将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其实并没有原生支持这种方式(小道消息,下个版本会支持)。我推荐使用这篇帖子的方式:http://jaminquimby.com/servers/95-sql/sql-2008/145-code-tsql-convert-query-to-json来做。将该帖子所提供的存储过程建立完成后,使用如下BCP命令:

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

相关内容
- sql server中Select count(*)和Count(1)的区别和执行方式_MsSql_
- SQL Server中使用SQL语句实现把重复行数据合并为一行并用逗号分隔_MsSql_
- SQL Server中统计每个表行数的快速方法_MsSql_
- Sql Server中的事务介绍_MsSql_
- Sql Server中的视图介绍_MsSql_
- SQL Server数据库中的存储过程介绍_MsSql_
- SQL Server 2012 创建定时作业(图文并茂,教你轻松快速创建)_MsSql_
- sql server启动不了, MSSQL 18052错误: 9003,严重度: 20,状态: 1 ._MsSql_
- 简单判断MSSQL数据库版本(2000或者2005)_MsSql_
- win2008 r2 安装sql server 2005/2008 无法连接服务器解决方法_MsSql_
