SQL Server 與 Excel

來源:互聯網
上載者:User

/*
預存程序名稱:匯出資料到Excel
功能描述:匯出資料到Excel

EXEC ExportToExcel @server = '.',
                   @uname = 'sa',
                   @pwd = '',
                   @QueryText = 'SELECT * FROM dldata..bbbbbb',
                   @filename = 'd:/ImportToExcel.xls'
*/

IF OBJECT_ID('ExportToExcel') IS NOT NULL DROP PROC ExportToExcel
GO

CREATE PROCEDURE ExportToExcel (
  @server sysname = null,
  @uname sysname = null,
  @pwd sysname = null,
  @QueryText varchar(200) = null,
  @filename varchar(200) = 'd:/ImportToExcel.xls'
)
AS
DECLARE @SQLServer int, --SQLDMO.SQLServer對象
        @QueryResults int, --QueryResults對象
        @CurrentResultSet int,
        @object int, --Excel.Application對象
        @WorkBooks int,
        @WorkBook int,
        @Range int,
        @hr int,
        @Columns int,
        @Rows int,
        @indColumn int,
        @indRow int,
        @off_Column int,
        @off_Row int,
        @code_str varchar(100),
        @result_str varchar(255)

IF @QueryText IS NULL
BEGIN
   PRINT 'Set the query string'
   RETURN
END

--設定伺服器名為本機伺服器(@@servername返回運行SQL Server的本機伺服器名稱)
IF @server IS NULL SELECT @server = @@servername

--設定使用者名稱為當前系統使用者名稱(使用SYSTEM_USER返回當前系統使用者名稱)
IF @uname IS NULL SELECT @uname = SYSTEM_USER

SET NOCOUNT ON

--建立SQLDMO.SQLServer對象
EXEC @hr = sp_OACreate 'SQLDMO.SQLServer', @SQLServer OUT
IF @hr <> 0
BEGIN
   PRINT 'error create SQLDMO.SQLServer'
   RETURN
END

--串連到SQL Server系統
IF @pwd IS NULL
BEGIN
   EXEC @hr = sp_OAMethod @SQLServer, 'Connect', null, @server, @uname
   IF @hr <> 0
   BEGIN
      PRINT 'error Connect'
      RETURN
   END
END
ELSE
BEGIN
   EXEC @hr = sp_OAMethod @SQLServer, 'Connect', null, @server, @uname, @pwd
   IF @hr <> 0
   BEGIN
      PRINT 'error Connect'
      RETURN
   END
END

--The ExecuteWithResults method executes a Transact-SQL command batch
--returning batch result sets in a QueryResults object
SELECT @result_str = 'ExecuteWithResults("' + @QueryText + '")'
EXEC @hr = sp_OAMethod @SQLServer, @result_str, @QueryResults OUT
IF @hr <> 0
BEGIN
    PRINT 'error with method ExecuteWithResults'
    RETURN
END

--The CurrentResultSet property controls access to the result sets of a QueryResults object
EXEC @hr = sp_OAMethod @QueryResults, 'CurrentResultSet', @CurrentResultSet OUT
IF @hr <> 0
BEGIN
   PRINT 'error get CurrentResultSet'
   RETURN
END

--The Columns property exposes the number of columns contained
--in the current result set of a QueryResults object
EXEC @hr = sp_OAMethod @QueryResults, 'Columns', @Columns OUT
IF @hr <> 0
BEGIN
   PRINT 'error get Columns'
   RETURN
END

--The Rows property returns the number of rows in a referenced
--query result set or the number of rows existing in a table
EXEC @hr = sp_OAMethod @QueryResults, 'Rows', @Rows OUT
IF @hr <> 0
BEGIN
   PRINT 'error get Rows'
   RETURN
END

--建立Excel.Application對象
EXEC @hr = sp_OACreate 'Excel.Application', @object OUT
IF @hr <> 0
BEGIN
   PRINT 'error create Excel.Application'
   RETURN
END

--獲得Excel活頁簿對象
EXEC @hr = sp_OAGetProperty @object, 'WorkBooks', @WorkBooks OUT
IF @hr <> 0
BEGIN
   PRINT 'error create WorkBooks'
   RETURN
END

--在活頁簿對象中加入一工作表
EXEC @hr = sp_OAGetProperty @WorkBooks, 'Add', @WorkBook OUT
IF @hr <> 0
BEGIN
   PRINT 'error with method Add'
   RETURN
END

--Range對象(A1儲存格)
EXEC @hr = sp_OAGetProperty @object, 'Range("A1")', @Range OUT
IF @hr <> 0
BEGIN
   PRINT 'error create Range'
   RETURN
END

SELECT @indRow = 1
SELECT @off_Row = 0
SELECT @off_Column = 1

WHILE (@indRow <= @Rows)
BEGIN
   SELECT @indColumn = 1
   WHILE (@indColumn <= @Columns)
   BEGIN
      --The GetColumnString method returns a QueryResults object result set member converted to a String value
      EXEC @hr = sp_OAMethod @QueryResults, 'GetColumnString', @result_str OUT, @indRow, @indColumn
      IF @hr <> 0
      BEGIN
         PRINT 'error get GetColumnString'
         RETURN
      END

      EXEC @hr = sp_OASetProperty @Range, 'value', @result_str
      IF @hr <> 0
      BEGIN
         PRINT 'error set value'
         RETURN
      END

      EXEC @hr = sp_OAGetProperty @Range, 'Offset', @Range OUT, @off_Row, @off_Column
      IF @hr <> 0
      BEGIN
         PRINT 'error get Offset'

         RETURN
      END

      SELECT @indColumn = @indColumn + 1

   END

   SELECT @indRow = @indRow + 1
   SELECT @code_str = 'Range("A' + LTRIM(str(@indRow)) + '")'
   EXEC @hr = sp_OAGetProperty @object, @code_str, @Range OUT
   IF @hr <> 0
   BEGIN
      PRINT 'error create Range'
      RETURN
   END

END

SELECT @result_str = 'exec master..xp_cmdshell ''del ' + @filename + ''', no_output'
EXEC(@result_str) --如果存在@filename檔案,則先刪除
SELECT @result_str = 'SaveAs("' + @filename + '")'
EXEC @hr = sp_OAMethod @WorkBook, @result_str
IF @hr <> 0
BEGIN
    PRINT 'error with method SaveAs'
    RETURN
END

EXEC @hr = sp_OAMethod @WorkBook, 'Close'
IF @hr <> 0
BEGIN
    PRINT 'error with method Close'
    RETURN
END

EXEC @hr = sp_OADestroy @object
IF @hr <> 0
BEGIN
    PRINT 'error destroy Excel.Application'
    RETURN
END

EXEC @hr = sp_OADestroy @SQLServer
IF @hr <> 0
BEGIN
    PRINT 'error destroy SQLDMO.SQLServer'
    RETURN
END
GO

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.