熱線電話:13121318867

登錄
首頁精彩閱讀SQL Server表中數據按條件批量導出為多個Excel
SQL Server表中數據按條件批量導出為多個Excel
2017-12-28
收藏

SQL Server表中數據按條件批量導出為多個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

以下是代碼片段:

    --聲明需要的變量     
    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   

  以上就是SQL Server表中數據按條件批量導出為多個Excel文件的實現方法,本文就介紹到這里了,希望本次的介紹能夠對您有所收獲!

SQL

數據分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數據分析師資訊
更多

OK
客服在線
立即咨詢
日韩人妻系列无码专区视频,先锋高清无码,无码免费视欧非,国精产品一区一区三区无码
客服在線
立即咨詢