sql server表中数据按条件批量导出为多个excel文件是本文我们主要要介绍的内容,在一次sql server数据库的操作中,需要将某个有数十万行数据的表按类别导出为xls文件,每个类别一个xls。将数据表中的数据导出并保存为xls简单,用 ssis或者查询出来之后另存为
sql server表中数据按条件批量导出为多个excel文件是本文我们主要要介绍的内容,在一次sql server数据库的操作中,需要将某个有数十万行数据的表按类别导出为xls文件,每个类别一个xls。将数据表中的数据导出并保存为xls简单,用 ssis或者查询出来之后另存为都可以。但是,,这个表中的分类有数百个,如果一个个用ssis或者查询另存为的话,工作量巨大。前思后想,想到了用 while循环查询,并用bcp导出的方法。
下面是相关代码:
--声明需要的变量
declare @sql varchar(600),@typeid int
--确认第一个分类的id
select @typeid=min(typeid) from t_testtable
--当存在满足分类id的记录时进行处理
while exists(select 1 from t_testtable where typeid=@typeid)
begin
--拼凑需要执行的语句
set @sql='bcp select * from (select'+'''列名1'''+' as 列名1,'+'''列名2'''+' as 列名2,'+'''列名3'''+' as 列名3'--在xls文件中显示列名
set @sql=@sql+' union all select 列名1,列名2,列名3 from t_testtable where typeid='+cast(@typeid as varchar(8))+')a queryout f:datafiletypedata'+cast(@typeid as varchar(8))+'.xls -c -q -sservername -usa -psapassword -ddbname'--查询满足条件的记录并保存到xls文件中
--使用xp_cmdshell系统存储过程执行拼凑好的语句(需要使用高级选项开关预先开启cmdshell组件)
exec master..xp_cmdshell @sql
--获得下一个分类的id(分类id是不连续的)
select @typeid=isnull(min(typeid),@typeid+1) from t_testtable where typeid>=@typeid+1
end
以上就是sql server表中数据按条件批量导出为多个excel文件的实现方法,本文就介绍到这里了,希望本次的介绍能够对您有所收获!