如何將SQL Server數據表中的數據按條件批量導出爲多個Excel文件

昨天,某位大大提了個要求,需要將某個有數十萬行數據的表按類別導出爲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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章