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


PipelineComponent.BufferManager Свойство

Определение

Важно!

Этот API несовместим с CLS.

Возвращает объект IDTSBufferManager100 компонента конвейера.

public:
 property Microsoft::SqlServer::Dts::Pipeline::Wrapper::IDTSBufferManager100 ^ BufferManager { Microsoft::SqlServer::Dts::Pipeline::Wrapper::IDTSBufferManager100 ^ get(); };
[System.CLSCompliant(false)]
public Microsoft.SqlServer.Dts.Pipeline.Wrapper.IDTSBufferManager100 BufferManager { get; }
[<System.CLSCompliant(false)>]
member this.BufferManager : Microsoft.SqlServer.Dts.Pipeline.Wrapper.IDTSBufferManager100
Public ReadOnly Property BufferManager As IDTSBufferManager100

Значение свойства

Объект IDTSBufferManager100.

Атрибуты

Примеры

В следующем примере кода показано, как использовать BufferManager свойство для поиска столбцов в строке PipelineBuffer .

using System;  
using Microsoft.SqlServer.Dts.Pipeline;  
using Microsoft.SqlServer.Dts.Pipeline.Wrapper;  
using Microsoft.SqlServer.Dts.Runtime.Wrapper;  

namespace Microsoft.Samples.SqlServer.Dts  
{  
    public class SampleComponent : PipelineComponent  
    {  
        public override void ProcessInput( int InputID, PipelineBuffer buffer )  
        {  
            IDTSInput100 i = ComponentMetaData.InputCollection.GetObjectByID( InputID );  
            foreach( IDTSInputColumn100 col in i.InputColumnCollection)  
            {  
                int colIndex = BufferManager.FindColumnByLineageID(i.Buffer, col.LineageID);  
                BufferColumn bc =buffer.GetColumnInfo(colIndex);  
            }  
        }  
    }  
}  
Imports System   
Imports Microsoft.SqlServer.Dts.Pipeline   
Imports Microsoft.SqlServer.Dts.Pipeline.Wrapper   
Imports Microsoft.SqlServer.Dts.Runtime.Wrapper   
Namespace Microsoft.Samples.SqlServer.Dts   

 Public Class SampleComponent   
 Inherits PipelineComponent   

   Public Overrides Sub ProcessInput(ByVal InputID As Integer, ByVal buffer As PipelineBuffer)   
     Dim i As IDTSInput100 = ComponentMetaData.InputCollection.GetObjectByID(InputID)   
     For Each col As IDTSInputColumn100 In i.InputColumnCollection   
       Dim colIndex As Integer = BufferManager.FindColumnByLineageID(i.Buffer, col.LineageID)   
       Dim bc As BufferColumn = buffer.GetColumnInfo(colIndex)   
     Next   
   End Sub   
 End Class   
End Namespace  

Комментарии

Это BufferManager свойство только для чтения, свойство времени выполнения, которое впервые доступно компонентам в методе PreExecute .

Этот FindColumnByLineageID метод используется для поиска столбцов компонента в IDTSInputColumnCollection100 компоненте или IDTSOutputColumnCollection100 компоненте PipelineBuffer. Это необходимо, так как количество столбцов, содержащихся в нем PipelineBuffer , может превышать количество столбцов, ожидаемых компонентом.

Он BufferManager также используется для создания новых IDTSBuffer100 объектов с помощью CreateBufferCreateFlatBufferCreateVirtualBuffer и методов. Однако эти методы не поддерживаются из управляемого кода и должны использоваться только при написании собственных компонентов C++.

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