Compartilhar via


PipelineComponent.BufferManager Propriedade

Definição

Importante

Esta API não está em conformidade com CLS.

Obtém o IDTSBufferManager100 de um componente de pipeline.

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

Valor da propriedade

O objeto IDTSBufferManager100.

Atributos

Exemplos

O exemplo de código a seguir mostra como usar a BufferManager propriedade para localizar as colunas em uma PipelineBuffer linha.

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  

Comentários

É BufferManager uma propriedade somente leitura e tempo de execução que está disponível primeiro para componentes no PreExecute método.

O FindColumnByLineageID método é usado para localizar as colunas de um componente no IDTSInputColumnCollection100 componente ou IDTSOutputColumnCollection100 no PipelineBuffer. Isso é necessário porque o número de colunas contidas no PipelineBuffer pode exceder o número de colunas esperadas pelo componente.

O BufferManager também é usado para criar novos IDTSBuffer100 objetos usando os métodos e CreateVirtualBuffer o CreateBuffer. CreateFlatBuffer No entanto, esses métodos não têm suporte do código gerenciado e só devem ser usados ao escrever componentes C++ nativos.

Aplica-se a