0
A
回答
2
它們同樣命名爲轉換,但用途各不相同。目標就是它聽起來像 - 它是數據流的終點。您無法將任何內容連接到OLE DB目標的輸出(超出錯誤流程)。目的地有能力執行集合基於插入(這對於良好性能非常重要)。它也可以執行單例插入(爲每個行發出一條插入語句,用於),這會導致流向目標的吞吐量較低。
將該行爲與OLE DB命令進行對比。這是一個轉換組件,它允許您爲流過數據流的每一行執行任何操作。這是一把瑞士軍刀SQL「執行者」。你可以使用它作爲INSERT語句,但最常見的是我將它看作UPDATE目標。對於小數據集,這很好。使用OLE DB命令轉換的成本是成本。它將爲流經數據集的每一行發佈單例語句。就事務日誌,交易時間,計劃緩存以及其他一些我無法想象的事情而言,這將會代價高昂。沒有辦法告訴SQL Server對這些操作進行批處理,因此您將被縮減爲通過激動行(RBAR)發佈語句行。
如果您需要在SSIS中執行更新,您可以通過將更新寫入臨時表並在數據流完成後執行基於集的更新來獲得更好的性能配置文件。 Andy Leonard在他的Stairway to Integration Services series上有一系列討論這種模式的文章。
參考
1
一個OLE目的地爲刀片更好的選擇,因爲它允許數據的批量加載到目標表。
一個OLE DB命令(我認爲是你的意思是OLE命令任務)將逐行執行它的操作,這是慢得多的。雖然,OLE DB命令可以處理更新並刪除哪個OLE目標不能使用
相關問題
- 1. OLE DB源組件到OLE DB目標
- 2. 插入命令OLE參數
- 3. 動態SQL與SSIS OLE DB命令
- 4. 與OLE DB命令SSIS錯誤
- 5. SSIS- OLE DB來源到OLE DB目標錯誤
- 6. SSIS OLE目標多個錯誤輸出
- 7. OLE DB目的地任務在值的端
- 8. EzAPI OLE DB目的地
- 9. OLE:爲多個OLE對象共享IStorage?
- 10. C#的COM OLE服務器
- 11. 從目標DB使用查詢來限制OLE DB源任務在SSIS 2008
- 12. Javascript OLE Word
- 13. OLE pdf控件
- 14. perl win32 ole timeout
- 15. 什麼是OLE
- 16. OLE錯誤C0000094
- 17. 多個OLE DB SSIS交易指令
- 18. SSIS - 更新一個表,一個OLE DB命令
- 19. 使用OLE DB命令組件更新記錄SSIS
- 20. 無法在變量傳遞到OLE DB源命令
- 21. 在OLE DB命令(SSIS)後捕獲受影響的行計數
- 22. SSIS錯誤(查找和OLE DB命令)的問題
- 23. 使用OLE DB命令轉換的SSIS包錯誤
- 24. OLE DB命令中存儲過程的SSIS返回值
- 25. SSIS OLE DB命令日期參數格式
- 26. 爲什麼OLE DB命令試圖更新模式?
- 27. OLE DB命令在SSIS持有表排它鎖無限期
- 28. Visual C#中用於分割串行數據的OLE DB命令
- 29. Undeclared identifier .WorkSheets OLE Excel
- 30. OLE date(number)date(string)