사용자 지정 Foreach 열거자 코딩
적용 대상: Azure Data Factory의 SQL Server SSIS Integration Runtime
기본 클래스에서 ForEachEnumerator 상속되는 클래스를 만들고 클래스에 DtsForEachEnumeratorAttribute 특성을 적용한 후에는 기본 클래스의 속성 및 메서드 구현을 재정의하여 사용자 지정 기능을 제공해야 합니다.
사용자 지정 열거자의 작업 샘플은 사용자 지정 ForEach 열거자에 대한 사용자 인터페이스 개발을 참조 하세요.
열거자 초기화
이 메서드를 재정의 InitializeForEachEnumerator 하여 패키지에 정의된 연결 관리자에 대한 참조를 캐시하고 오류, 경고 및 정보 메시지를 발생시키는 데 사용할 수 있는 이벤트 인터페이스에 대한 참조를 캐시할 수 있습니다.
열거자 유효성 검사
Validate 메서드를 재정의하여 열거자가 올바르게 구성되어 있는지 확인할 수 있습니다. 메서드가 Failure를 반환하는 경우 열거자와 열거자를 포함하는 패키지가 실행되지 않습니다. 이 메서드의 구현은 각 열거자와 관련이 있지만 열거자가 사용하거나 ConnectionManager 개체를 사용하는 경우 메서드에 Variable 제공된 컬렉션에 이러한 개체가 있는지 확인하는 코드를 추가해야 합니다.
다음 코드 예제에서는 열거자의 Validate 속성에 지정된 변수를 검사하는 구현을 보여 줍니다.
private string variableNameValue;
public string VariableName
{
get{ return this.variableNameValue; }
set{ this.variableNameValue = value; }
}
public override DTSExecResult Validate(Connections connections, VariableDispenser variableDispenser, IDTSInfoEvents infoEvents, IDTSLogging log)
{
if (!variableDispenser.Contains(this.variableNameValue))
{
infoEvents.FireError(0, "MyEnumerator", "The Variable " + this.variableNameValue + " does not exist in the collection.", "", 0);
return DTSExecResult.Failure;
}
return DTSExecResult.Success;
}
Private variableNameValue As String
Public Property VariableName() As String
Get
Return Me.variableNameValue
End Get
Set (ByVal Value As String)
Me.variableNameValue = value
End Set
End Property
Public Overrides Function Validate(ByVal connections As Connections, ByVal variableDispenser As VariableDispenser, ByVal infoEvents As IDTSInfoEvents, ByVal log As IDTSLogging) As DTSExecResult
If Not variableDispenser.Contains(Me.variableNameValue) Then
infoEvents.FireError(0, "MyEnumerator", "The Variable " + Me.variableNameValue + " does not exist in the collection.", "", 0)
Return DTSExecResult.Failure
End If
Return DTSExecResult.Success
End Function
컬렉션 반환
실행 중 ForEachLoop 컨테이너는 사용자 지정 열거자의 GetEnumerator 메서드를 호출합니다. 이 메서드에서 열거자는 해당 항목 컬렉션을 만들고 채운 다음 컬렉션을 반환합니다. 그런 다음 ForEachLoop는 컬렉션의 항목을 반복하고 컬렉션의 각 항목에 대한 제어 흐름을 실행합니다.
다음 예제에서는 임의 GetEnumerator 정수 배열을 반환하는 구현을 보여 줍니다.
public override object GetEnumerator()
{
ArrayList numbers = new ArrayList();
Random randomNumber = new Random(DateTime.Now);
for( int x=0; x < 100; x++ )
numbers.Add( randomNumber.Next());
return numbers;
}
Public Overrides Function GetEnumerator() As Object
Dim numbers As ArrayList = New ArrayList()
Dim randomNumber As Random = New Random(DateTime.Now)
Dim x As Integer
For x = 0 To 100- 1 Step x + 1
numbers.Add(randomNumber.Next())
Next
Return numbers
End Function