SQL表中数据按条件批量导出多个Excel文件
2011-12-03 13:45
766 查看
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 -S"ServerName" -U"sa" -P"SAPASSWORD" -d"DBName"'--查询满足条件的记录并保存到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 |
相关文章推荐
- 框架 day50 BOS项目 4 批量导入(ocupload插件,pinyin4J)/POI解析Excel/Combobox下拉框/分区组合条件分页查询(ajax)/分区数据导出(Excel)
- 上传excel文件实现批量导入数据及导出数据为excel文件
- SQL Server表中数据按条件批量导出为多个Excel
- 如何将SQL Server数据表中的数据按条件批量导出为多个Excel文件
- 使用POI将数据导出到Excel文件
- PHP导出MySQL数据到Excel文件
- C# win form 中 将数据导出为简单Excel文件
- VB6数据导出到Excel文件,一种设计界面查询条件的方法,一种简单加密方法(改写)
- 使用PHP导入Excel和导出数据为Excel文件
- SQL Server中bcp命令的用法以及数据批量导入导出
- 数据批量导出到excel文件中思路
- 批量快速的导入导出Oracle的数据
- Codeigniter+PHPExcel实现导出数据到Excel文件
- DBGridEh 导出数据到EXCEL文件
- 03: 数据导入导出 、 表记录基本操作 、 查询及匹配条件 、 多表查询
- 根据条件筛选导出MySQL数据表中的数据
- update关联其他表批量更新数据-跨数据库-跨服务器Update时关联表条件更新
- 利用POI工具包导出数据到Excel文件
- 使用存储过程将Oracle数据批量导出为多个csv文件
- 使用存储过程将Oracle数据批量导出为多个csv文件