导出为TXT文件***********************
通用过程,实现将数据库中的表与文本文件之间的数据导入/导出.
/*
实现数据导入/导出的存储过程
调用示例:
--导出调用示例
exec file2table 'zj','','','xzkh_sa..地区资料','c:\zj.txt',1
--导入调用示例
exec file2table 'zj','','','xzkh_财务..凭证库','c:\zj.txt',0
*/
if exists(select 1 from sysobjects where name='File2Table' and objectproperty(id,'IsProcedure')=1)
drop procedure File2Table
go
create procedure File2Table
@servername varchar(200) --服务器名
,@username varchar(200) --用户名,如果用NT验证方式,则为空''
,@password varchar(200) --密码
,@tbname varchar(500) --表名,必须指定数据库缀,即用 数据库名.dob.表中的形式
,@filename varchar(1000) --导入/导出文件名,带路径
,@isout bit --1为导出,0为导入
as
declare @sql varchar(8000)
set @sql='bcp '+@tbname
+case when @isout=1 then ' out ' else ' in ' end
+' "'+@filename+'" /w'
+' /S '+@servername
+case when isnull(@username,'')='' then '' else ' /U '+@username end
+' /P '+isnull(@password,'')
exec master..xp_cmdshell @sql
go
导出为多个Excel文件***********************
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:\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+1
- end