Поделиться через


DTSBufferManagerClass.FindColumnByLineageID(Int32, Int32) Метод

Определение

Возвращает местоположение столбца в указанном объекте IDTSBuffer100.

public:
 virtual int FindColumnByLineageID(int hBufferType, int nLineageID) = Microsoft::SqlServer::Dts::Pipeline::Wrapper::IDTSBufferManager100::FindColumnByLineageID;
public virtual int FindColumnByLineageID (int hBufferType, int nLineageID);
abstract member FindColumnByLineageID : int * int -> int
override this.FindColumnByLineageID : int * int -> int
Public Overridable Function FindColumnByLineageID (hBufferType As Integer, nLineageID As Integer) As Integer

Параметры

hBufferType
Int32

Идентификатор объекта IDTSBuffer100, который содержит столбец.

nLineageID
Int32

Идентификатор журнала обращений и преобразований искомого столбца в IDTSBuffer100.

Возвращаемое значение

Целое число, указывающее расположение по индексу столбца в .IDTSBuffer100

Реализации

Примеры

В следующем примере кода показано, как компонент преобразования без выходных столбцов используется FindColumnByLineageID для поиска входных столбцов в буфере.

int[] bufferColumnIndex;  
public override void PreExecute()  
{  
    IDTSInput100 input = ComponentMetaData.InputCollection[0];  
    bufferColumnIndex = new int[BufferManager.GetColumnCount(input.Buffer)];  

    for( int col=0; col < input.InputColumnCollection.Count; col++)  
    {  
        IDTSInputColumn100 iCol = input.InputColumnCollection[col];  
        bufferColumnIndex[col] = BufferManager.FindColumnByLineageID(input.Buffer, iCol.LineageID);  
    }  
}  
Private bufferColumnIndex As Integer()   

Public Overloads Overrides Sub PreExecute()   
 Dim input As IDTSInput100 = ComponentMetaData.InputCollection(0)   
 bufferColumnIndex = New Integer(BufferManager.GetColumnCount(input.Buffer) - 1) {}   
 Dim col As Integer = 0   
 While col < input.InputColumnCollection.Count   
   Dim iCol As IDTSInputColumn100 = input.InputColumnCollection(col)   
   bufferColumnIndex(col) = BufferManager.FindColumnByLineageID(input.Buffer, iCol.LineageID)   
   col -= 1   
 End While   
End Sub  

Комментарии

Этот метод находит столбец указанного объекта IDTSInput100 или IDTSOutput100 указанного IDTSBuffer100объекта. Этот метод необходим, поскольку экземпляр буфера содержит все IDTSOutputColumn100 объекты, определенные в IDTSOutputColumnCollection100 компонентах графа. Компоненты не могут полагаться на использование расположения индекса выходного столбца или входного столбца в качестве индекса этого столбца в строке буфера. Поэтому компоненты должны использовать FindColumnByLineageID метод для поиска столбцов в буфере.

Применяется к