다음을 통해 공유


스크립트 구성 요소의 오류 출력 시뮬레이션

적용 대상: Azure Data Factory의 SQL Server SSIS Integration Runtime

오류 행의 자동 처리를 위해 스크립트 구성 요소에서 출력을 오류 출력으로 직접 구성할 수는 없지만, 추가 출력을 만들고 스크립트의 조건부 논리를 사용하여 적절한 경우 행을 이 출력으로 전달하여 기본 제공 오류 출력의 기능을 재현할 수 있습니다. 오류 번호와 오류가 발생한 열의 ID를 받는 두 개의 출력 열을 추가하여 기본 제공 오류 출력의 동작을 시뮬레이션할 수 있습니다.

미리 정의된 특정 Integration Services 오류 코드에 해당하는 오류 설명을 추가하려면 스크립트 구성 요소의 ComponentMetaData 속성을 통해 사용할 수 있는 인터페이스의 IDTSComponentMetaData100 메서드를 사용할 GetErrorDescription 수 있습니다.

예시

이 예에서는 두 개의 동기 출력을 사용하는 변환으로 구성된 스크립트 구성 요소를 사용합니다. 스크립트 구성 요소의 목적은 AdventureWorks 샘플 데이터베이스의 주소 데이터에서 오류 행을 필터링하는 것입니다. 이 가상 예제에서는 북아메리카n 고객을 위한 프로모션을 준비하고 있으며 북아메리카 없는 주소를 필터링해야 한다고 가정합니다.

예제를 구성하려면

  1. 새 스크립트 구성 요소를 만들기 전에 연결 관리자를 만들고 AdventureWorks 샘플 데이터베이스에서 주소 데이터를 선택하는 데이터 흐름 원본을 구성합니다. CountryRegionName 열만 보는 이 예제에서는 Person.vStateCountryProvinceRegion 보기를 사용하거나 Person.Address, Person.StateProvince 및 Person.CountryRegion 테이블을 조인하여 데이터를 선택할 수 있습니다.

  2. 데이터 흐름 디자이너 화면에 새 스크립트 구성 요소를 추가하고 변환으로 구성합니다. 스크립트 변환 편집기를 엽니다.

  3. 스크립트 페이지에서 ScriptLanguage 속성을 스크립트를 코딩하는 데 사용할 스크립트 언어로 설정합니다.

  4. 스크립트 편집을 클릭하여 VsTA(Microsoft Visual Studio Tools for Applications)를 엽니다.

  5. Input0_ProcessInputRow 메서드에서 아래에 표시된 샘플 코드를 입력하거나 붙여넣습니다.

  6. VSTA를 닫습니다.

  7. 입력 열 페이지에서 스크립트 변환에서 처리할 열을 선택합니다. 이 예제에서는 CountryRegionName 열만 사용합니다. 선택하지 않은 상태로 두는 사용 가능한 입력 열은 데이터 흐름에서 변경되지 않은 상태로 전달됩니다.

  8. 입력 및 출력 페이지에서 새 두 번째 출력을 추가하고 해당 SynchronousInputID 값을 입력의 ID로 설정합니다. 이는 기본 출력의 SynchronousInputID 속성 값이기도 합니다. 두 출력 모두의 ExclusionGroup 속성을 0이 아닌 동일한 값(예: 1)으로 설정하여 각 행이 두 출력 중 하나로만 전송되도록 합니다. 새 오류 출력에 "MyErrorOutput"과 같은 고유한 이름을 지정합니다.

  9. 오류 코드, 오류가 발생한 열의 ID, 오류 설명 등 원하는 오류 정보를 캡처하는 출력 열을 새 오류 출력에 추가합니다. 이 예제에서는 새 열인 ErrorColumn 및 ErrorMessage를 만듭니다. 자체 구현에서 미리 정의된 Integration Services 오류를 catch하는 경우 오류 번호에 대한 ErrorCode 열을 추가해야 합니다.

  10. 입력 열의 ID 값은 스크립트 구성 요소에서 오류 조건을 확인하는 데 사용합니다. 이 예에서는 이 열 식별자를 사용하여 ErrorColumn 값을 채웁니다.

  11. 스크립트 변환 편집기를 닫습니다.

  12. 스크립트 구성 요소의 출력을 적절한 대상에 연결합니다. 임시 테스트용으로 구성하는 데는 플랫 파일 대상이 가장 쉽습니다.

  13. 패키지를 실행합니다.

Public Overrides Sub Input0_ProcessInputRow(ByVal Row As Input0Buffer)  
  
  If Row.CountryRegionName <> "Canada" _  
      And Row.CountryRegionName <> "United States" Then  
  
    Row.ErrorColumn = 68 ' ID of CountryRegionName column  
    Row.ErrorMessage = "Address is not in North America."  
    Row.DirectRowToMyErrorOutput()  
  
  Else  
  
    Row.DirectRowToOutput0()  
  
  End If  
  
End Sub  
public override void Input0_ProcessInputRow(Input0Buffer Row)  
{  
  
  if (Row.CountryRegionName!="Canada"&&Row.CountryRegionName!="United States")  
  
  {  
    Row.ErrorColumn = 68; // ID of CountryRegionName column  
    Row.ErrorMessage = "Address is not in North America.";  
    Row.DirectRowToMyErrorOutput();  
  
  }  
  else  
  {  
  
    Row.DirectRowToOutput0();  
  
  }  
  
}  

참고 항목

데이터 오류 처리
데이터 흐름 구성 요소에서 오류 출력 사용
스크립트 구성 요소를 사용하여 동기 변환 만들기