如何将SQL Server数据表中的数据按条件批量导出为多个Excel文件
来源:互联网 发布:c 中级程序员面试题 编辑:程序博客网 时间:2024/05/18 00:54
昨天,某位大大提了个要求,需要将某个有数十万行数据的表按类别导出为xls文件,每个类别一个xls。将数据表中的数据导出并保存为xls简单,用SSIS或者查询出来之后另存为都可以。但是,这个表中的分类有数百个,如果一个个用SSIS或者查询另存为的话,工作量巨大。前思后想,想到了用while循环查询,并用bcp导出的方法。下面是相关代码:
--声明需要的变量declare @sql varchar(600),@TypeID int--确认第一个分类的IDselect @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:\datafile\TypeData'+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+1end
- 如何将SQL Server数据表中的数据按条件批量导出为多个Excel文件
- SQL Server表中数据按条件批量导出为多个Excel
- SQL表中数据按条件批量导出多个Excel文件
- 将SQL Server 2005中的数据导出为Excel
- 将Sql Server数据库中的数据导出为Sql文件
- SQL Server表中数据导出为多个Excel文件和TXT文件
- 将mysql数据表导出为excel文件
- excel数据批量导出为sql脚本
- 将SQL Server数据表导出到Excel中
- 将数据库中的数据导出为excel文件 HSSFWorkBooK用法
- 将MSHFlexgrid中的数据导出为Excel文件
- 机房收费-将MSHFlexgrid中的数据导出为Excel文件
- 将r中的数据导出为excel文件
- 将数据库中的数据导出为Excel文件
- 使用存储过程将Oracle数据批量导出为多个csv文件
- 使用存储过程将数据批量导出为多个csv文件(ORACLE)
- 使用存储过程将Oracle数据批量导出为多个csv文件
- 将excel文件中的数据导入导出至SQL数据库
- testdirector 打开页面后,不能浏览
- 在网页中嵌入skype、msn、QQ按钮
- MyEclipse优化加载速度和去掉一些没用的设置
- delphi中create的用法一直不是很清楚 有没有系统全面的介绍
- firefox不显示table,ie中能显示
- 如何将SQL Server数据表中的数据按条件批量导出为多个Excel文件
- Mysql源代码分析(7):MYISAM的数据文件处理--转载
- DNS及mDNS 名字(名称)压缩规则
- 问题:linux虚拟机能ping通且可以远程登录,为什么客户端连不上服务器呢?sipp
- 编译程序和操作系统
- table/segment/extent/block之间关系
- table 按列进行排序
- 阅读类应用精选
- 80X86保护模式内存管理