共用方式為


SQL Server 目的地

適用於:SQL Server Azure Data Factory 中的 SSIS Integration Runtime

SQL Server 目的地會連線到本機 SQL Server 資料庫,並大量載入資料到 SQL Server 資料表和檢視中。 如果套件會存取遠端伺服器上的 SQL Server 資料庫,您就無法在這種套件中使用 SQL Server 目的地。 反之,這種封裝應該使用 OLE DB 目的地。 如需詳細資訊,請參閱 OLE DB Destination

權限

使用者必須擁有「建立全域物件」權限,才能執行包含 SQL Server 目的地的封裝。 您可以使用「本機安全性原則」工具 (從 [系統管理工具] 功能表中開啟) 將此權限授與使用者。 如果您在執行使用 SQL Server 目的地的封裝時收到錯誤訊息,請確定執行該封裝的帳戶是否擁有「建立全域物件」權限。

大量插入

如果您嘗試使用 SQL Server 目的地將資料大量載入遠端 SQL Server 資料庫,可能會看到類似下面這樣的錯誤訊息:「有 OLE DB 記錄可用」。 來源:"Microsoft SQL Server Native Client" Hresult: 0x80040E14 描述: 「無法大量載入,因為無法開啟 SSIS 檔案對應物件 'Global\DTSQLIMPORT '」。 作業系統錯誤碼 2 (系統找不到指定的檔案)。 請確定是透過 Windows 安全性存取本機伺服器」。

SQL Server 目的地也可以對 SQL Server 進行高速資料插入 (如同「大量插入」工作提供的一樣);不過,透過使用 SQL Server 目的地,套件可以先套用轉換到資料行資料,再將資料載入 SQL Server。

若要將資料載入 SQL Server,您應該考慮使用 SQL Server 目的地,而不是 OLE DB 目的地。

大量插入選項

如果 SQL Server 目的地使用快速載入資料存取模式,則您可以指定下列快速載入選項:

  • 保留匯入資料檔中的識別值或使用 SQL Server 指派的唯一值。

  • 大量載入作業期間保留 Null 值。

  • 大量匯入作業期間驗證目標資料表或檢視的條件約束。

  • 大量載入作業期間需要資料表層級鎖定。

  • 大量載入作業期間執行目的地資料表上定義的插入觸發器。

  • 在大量插入作業期間,指定輸入中要載入的第一個資料列編號。

  • 大量插入作業期間指定要載入之輸入的最後一個資料列編號。

  • 指定在取消大量載入作業之前,允許發生錯誤的最多數目。 每個無法匯入的資料列都將算為一個錯誤。

  • 指定輸入中包含已排序資料的資料行。

如需大量載入選項的詳細資訊,請參閱 BULK INSERT (Transact-SQL)

效能改善

若要提升大量插入以及大量插入作業期間存取資料表資料的效能,您應該變更預設選項,如下:

  • 大量匯入作業期間不驗證目標資料表或檢視的條件約束。

  • 大量載入作業期間不執行目的地資料表上定義的插入觸發器。

  • 不要將鎖定套用到資料表。 這樣,在大量插入作業期間,其他使用者和應用程式依然可以使用該資料表。

SQL Server 目的地的組態

您可以利用下列方式設定 SQL Server 目的地:

  • 指定要大量載入資料的資料表或檢視。

  • 透過指定一些選項 (例如是否要檢查條件約束的選項) 來自訂大量載入作業。

  • 指定所有資料列是以一個批次認可,或設定每個批次所認可的最大資料列數。

  • 指定大量載入作業的逾時。

此目的地使用 OLE DB 連接管理員連接到資料來源,且連接管理員會指定要使用的 OLE DB 提供者。 如需相關資訊,請參閱 OLE DB Connection Manager

Integration Services 專案還會提供資料來源物件,您可以從中建立 OLE DB 連線管理員。 這樣就可以向 SQL Server 目的地提供資料來源和資料來源檢視。

SQL Server 目的地有一個輸入。 它不支援錯誤輸出。

您可以透過 SSIS 設計師或以程式設計方式設定屬性。

[進階編輯器] 對話方塊會反映能以程式設計的方式設定之屬性。 如需有關可以在 [進階編輯器] 對話方塊中或以程式設計方式設定之屬性的詳細資訊,請按下列其中一個主題:

如需有關如何設定屬性的詳細資訊,請按下列其中一個主題:

SQL 目的地編輯器 (連接管理員頁面)

使用 [SQL 目的地編輯器] 對話方塊的 [連接管理員] 頁面,即可指定資料來源資訊並預覽結果。 SQL Server 目的地會將資料載入 Microsoft SQL Server 資料庫中的資料表或檢視。

選項。

[無快取]
從清單中選取現有的連接,或按一下 [新增] 來建立新的連接。

新增
使用 [設定 OLE DB 連接管理員] 對話方塊來建立新的連接。

使用資料表或檢視
從清單中選取現有的資料表或檢視,或按一下 [新增] 來建立新的連接。

新增
使用 [建立資料表] 對話方塊建立新的資料表。

注意

當您按一下 [新增] 時,Integration Services 會根據連線的資料來源,產生預設的 CREATE TABLE 陳述式。 這個預設 CREATE TABLE 陳述式將不會包含 FILESTREAM 屬性,即使來源資料表包含有宣告 FILESTREAM 屬性的資料行亦然。 若要執行具有 FILESTREAM 屬性的 Integration Services 元件,請先在目的地資料庫上實作 FILESTREAM 儲存體。 然後在 [建立資料表] 對話方塊中,將 FILESTREAM 屬性加入至 CREATE TABLE 陳述式。 如需詳細資訊,請參閱二進位大型物件 (Blob) 資料 (SQL Server)

預覽
使用 [預覽查詢結果] 對話方塊來預覽結果。 預覽最多可顯示 200 個資料列。

SQL 目的地編輯器 (對應頁面)

使用 [SQL 目的地編輯器] 對話方塊的 [對應] 頁面,即可將輸入資料行對應至目的地資料行。

選項。

可用的輸入資料行
檢視可用的輸入資料行清單。 使用拖放作業,即可將資料表中的可用輸入資料行對應到目的地資料行。

可用的目的地資料行
檢視可用的目的地資料行清單。 使用拖放作業,即可將資料表中的可用目的地資料行對應到輸入資料行。

輸入資料行
從上述資料表檢視選取的輸入資料行。 您可以使用 [可用的輸入資料行] 清單來變更對應。

目的地資料行
檢視每個可用的目的地資料行,不論是否已經對應。

SQL 目的地編輯器 (進階頁面)

使用 [SQL 目的地編輯器] 對話方塊的 [進階] 頁面,即可指定進階大量插入選項。

選項。

保留識別
指定工作是否應該將值插入識別欄位中。 此屬性的預設值為 False

保留 Null
指定工作是否應該保留 Null 值。 此屬性的預設值為 False

資料表鎖定
指定載入資料時是否鎖定資料表。 這個屬性的預設值為 True

檢查條件約束
指定工作是否應該檢查條件約束。 這個屬性的預設值為 True

引發觸發程序
指定大量插入是否應該引發資料表上的觸發程序。 此屬性的預設值為 False

第一個資料列
指定要插入的第一個資料列。 此屬性的預設值為 -1,表示未指派任何值。

注意

清除 [SQL 目的地編輯器] 中的文字方塊,以指出您不要指派此屬性的值。 在 [屬性] 視窗、[進階編輯器] 和物件模型中,請使用 -1。

最後一個資料列
指定要插入的最後一個資料列。 此屬性的預設值為 -1,表示未指派任何值。

注意

清除 [SQL 目的地編輯器] 中的文字方塊,以指出您不要指派此屬性的值。 在 [屬性] 視窗、[進階編輯器] 和物件模型中,請使用 -1。

最大錯誤數目
指定停止大量插入之前可以發生的錯誤數目。 此屬性的預設值為 -1,表示未指派任何值。

注意

清除 [SQL 目的地編輯器] 中的文字方塊,以指出您不要指派此屬性的值。 在 [屬性] 視窗、[進階編輯器] 和物件模型中,請使用 -1。

逾時
指定因逾時而停止大量插入之前要等候的秒數。

排序資料行
輸入排序資料行的名稱。 每個資料行都可依遞增或遞減順序來排序。 如果您使用多個排序資料行,請用逗號分隔此清單。

另請參閱

資料流程