在SSIS中,Package是Task組件的有序組合,具有層次結構,Package處于層次結構的頂層(Root Level),對于父子包結構,父包(Parent Package)通過Execute Package Task組件調用其他Package,被調用的Package是子包,父包是子包的上層級別,最頂層的Package,處于層次結構的頂層,叫做根包(Root Package);容器(Container)組件包含其他Task組件,容器是被包含的Task組件的父級別(Parent Level);Task組件是層次結構的最底層,處于葉級別(Leaf Level)。事件就是沿著Package的層次結構向上傳遞的。
在Package中,每一個Task組件都是一個可執(zhí)行程序(Executable),所有的數(shù)據(jù)處理任務都是由Task組件完成的。在Package運行(runtime)時,SSIS引擎為了監(jiān)控和追蹤Task組件的運行狀態(tài),預先創(chuàng)建了12個系統(tǒng)事件(Event),這些事件都是在Package運行時(runtime)被可執(zhí)行程序(Executable)觸發(fā)的,每個事件都會產生相應的消息,用于描述Executable的運行狀態(tài),供開發(fā)工程師對Package進行調試和性能調優(yōu)。一旦有事件被觸發(fā),SSIS會執(zhí)行相應的事件處理程序(Event Handler),SSIS為每個事件都創(chuàng)建了默認的事件處理程序,命名規(guī)范是:On+EventName,用戶可以創(chuàng)建自定義的事件處理程序,以擴展Package的功能,使Package在運行時更容易管理,以完成數(shù)據(jù)處理任務。在ETL開發(fā)中,最常用的事件是錯誤(Error)事件,該事件在Executable運行出現(xiàn)錯誤時觸發(fā),對應的事件處理程序是OnError。
在Package的層次結構中,事件處理具有向上傳遞(Propagate)的特性。發(fā)生在Task組件的事件,首先會被該Task組件的Event Handler捕獲和處理;如果該Task組件沒有創(chuàng)建Event Handler,那么SSIS把該Event向上傳遞到其父級別的Executable,由其父級別的Event Handler來處理;如果該Executable有Event Handler,那么由該Event Handler負責響應和處理該事件。事件會依次向上傳遞,直到事件被處理,或者傳遞到頂層被默認處理,事件向上傳遞的頂層是根包(Root Package)。
引用MSDN官方文檔的例子,Package的層次結構如下圖所示:
在層次結構中,如果相應