有时候需要一次性将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