Partager via


Classe PipelineBuffer

Provides an in-memory data store containing rows and columns of data.

Hiérarchie d'héritage

System.Object
  Microsoft.SqlServer.Dts.Pipeline.PipelineBuffer

Espace de noms :  Microsoft.SqlServer.Dts.Pipeline
Assembly :  Microsoft.SqlServer.PipelineHost (en Microsoft.SqlServer.PipelineHost.dll)

Syntaxe

'Déclaration
Public Class PipelineBuffer _
    Implements IDisposable
'Utilisation
Dim instance As PipelineBuffer
public class PipelineBuffer : IDisposable
public ref class PipelineBuffer : IDisposable
type PipelineBuffer =  
    class 
        interface IDisposable 
    end
public class PipelineBuffer implements IDisposable

Le type PipelineBuffer expose les membres suivants.

Constructeurs

  Nom Description
Méthode protégée PipelineBuffer(IntPtr, PipelineBufferMode) Instantiates a new instance of the PipelineBuffer.
Méthode publique PipelineBuffer(UInt32, UInt32, UInt64, IntPtr*, DTP_BUFFCOL*, Boolean)

Haut de la page

Propriétés

  Nom Description
Propriété publique ColumnCount Gets the number of columns in the PipelineBuffer.
Propriété publique ColumnInfo
Propriété publique CurrentRow Gets the index of the current row in the PipelineBuffer.
Propriété publique EndOfRowset Gets a value indicating whether the current PipelineBuffer is the final buffer.
Propriété publique Item Gets the data stored in a buffer column.
Propriété publique Mode Gets a value indicating whether a PipelineBuffer is an IDTSInput100 buffer or an IDTSOutput100 buffer.
Propriété publique RowCount Gets the number of rows in the PipelineBuffer object.
Propriété publique RowSize
Propriété publique RowStarts

Haut de la page

Méthodes

  Nom Description
Méthode publique AddBlobData(Int32, array<Byte[]) Adds an array of bytes to a PipelineBuffer column.
Méthode publique AddBlobData(Int32, array<Byte[], Int32) Adds an array of a specified number of bytes to a PipelineBuffer column.
Méthode publique AddRow Adds a row to the PipelineBuffer object.
Méthode publique DirectErrorRow(Int32, Int32, Int32) Sends a PipelineBuffer row to an IDTSOutput100 whose IsErrorOut property is true.
Méthode publique DirectErrorRow(Int32, Int32, Int32, Int32) Sends a PipelineBuffer row to an IDTSOutput100 whose IsErrorOut property is true.
Méthode publique DirectRow Sends a row from a PipelineBuffer to the specified IDTSOutput100.
Méthode publique Dispose() Releases all resources used by the PipelineBuffer.
Méthode protégée Dispose(Boolean) Releases the unmanaged resources that are used by the PipelineBuffer, and optionally releases the managed resources.
Méthode publique Equals (hérité de Object.)
Méthode protégée Finalize Releases all resources used by the PipelineBuffer. (remplace Object.Finalize().)
Méthode publique GetBlobData Retrieves an array of bytes from a binary large object (BLOB) stored in a PipelineBuffer column.
Méthode publique GetBlobLength Gets the number of bytes contained in a binary large object (BLOB) PipelineBuffer column.
Méthode publique GetBoolean Gets the bool value stored in the PipelineBuffer column.
Méthode publique GetByte Gets the byte value stored in the PipelineBuffer column.
Méthode publique GetBytes Gets the array of bytes stored in a buffer column.
Méthode publique GetColumnInfo Retrieves the BufferColumn structure for a PipelineBuffer column.
Méthode publique GetDate Gets the DateTime value stored in the PipelineBuffer column.
Méthode publique GetDateTime Gets the DateTime value stored in the PipelineBuffer column.
Méthode publique GetDateTimeOffset Gets the DateTimeOffset value stored in the PipelineBuffer column.
Méthode publique GetDecimal Gets the decimal value stored in the PipelineBuffer column.
Méthode publique GetDouble Gets the double stored in the PipelineBuffer column.
Méthode publique GetGuid Gets the Guid value stored in the PipelineBuffer column.
Méthode publique GetHashCode (hérité de Object.)
Méthode publique GetInt16 Gets the short stored in the PipelineBuffer column.
Méthode publique GetInt32 Gets the int stored in a PipelineBuffer column.
Méthode publique GetInt64 Gets the long stored in the PipelineBuffer column.
Méthode publique GetSByte Gets the SByte value stored in a PipelineBuffer column.
Méthode publique GetSingle Gets the float stored in a PipelineBuffer column.
Méthode publique GetString Gets the string stored in the buffer column.
Méthode publique GetTime Gets the TimeSpan value stored in the PipelineBuffer column.
Méthode publique GetType (hérité de Object.)
Méthode publique GetUInt16 Gets the ushort value stored in the buffer column.
Méthode publique GetUInt32 Gets the UInt32 value stored in the buffer column.
Méthode publique GetUInt64 Gets the ulong value stored in the buffer column.
Méthode publique IsNull Checks to see if the data in a buffer column is null.
Méthode protégée MemberwiseClone (hérité de Object.)
Méthode publique NextRow Advances the PipelineBuffer to the next row.
Méthode publique RemoveRow Removes the current row from the PipelineBuffer.
Méthode publique ResetBlobData Deletes the contents of the specified BLOB column.
Méthode publique SetBoolean Assigns a bool value to a PipelineBuffer column.
Méthode publique SetByte Assigns a byte to a PipelineBuffer column.
Méthode publique SetBytes Assigns an array of bytes to a buffer column.
Méthode publique SetDate Assigns a DateTime value to the PipelineBuffer column.
Méthode publique SetDateTime Assigns a DateTime value to the PipelineBuffer column.
Méthode publique SetDateTimeOffset Assigns a DateTimeOffset value to the PipelineBuffer column.
Méthode publique SetDecimal Assigns a decimal to a buffer column.
Méthode publique SetDouble Assigns a double to a PipelineBuffer column.
Méthode publique SetEndOfRowset Notifies the PipelineBuffer that a component has finished adding rows to the buffer.
Méthode publique SetErrorInfo Sets the error information for the current PipelineBuffer row.
Méthode publique SetGuid Assigns a Guid to a buffer column.
Méthode publique SetInt16 Assigns a 16-bit signed integer to a buffer column.
Méthode publique SetInt32 Assigns a 32-bit signed integer to a buffer column.
Méthode publique SetInt64 Assigns a 64-bit signed integer to a buffer column.
Méthode publique SetNull Assigns nullune référence Null (Nothing dans Visual Basic) to a buffer column.
Méthode publique SetSByte Assigns a signed 8-bit integer to a buffer column.
Méthode publique SetSingle Assigns a float to a buffer column.
Méthode publique SetString Assigns a string to a buffer column.
Méthode publique SetTime Assigns a TimeSpan value to the PipelineBuffer column.
Méthode publique SetUInt16 Assigns an unsigned 16-bit integer to a buffer column.
Méthode publique SetUInt32 Assigns an unsigned 32-bit integer to a buffer column.
Méthode publique SetUInt64 Assigns an unsigned 64-bit integer to a buffer column.
Méthode publique ToString (hérité de Object.)

Haut de la page

Notes

The PipelineBuffer is an in-memory two-dimensional data store containing rows and columns. It is created by the data flow task and supplied to managed data flow components during execution. The columns contained in a buffer are based on the columns in the IDTSOutputColumnCollection100 collections of the components in the graph.

Source components and components with asynchronous outputs receive a buffer for each of the output objects that are connected to a downstream component. These buffers are referred to as output buffers and do not contain rows. The component that receives the output buffer adds rows to the buffer and calls the SetEndOfRowset method when finished. This method sets the value of the EndOfRowset property to true on the final buffer. The data flow task then provides that buffer to the next component in the graph.

Transformation components with synchronous outputs and destination components receive PipelineBuffer objects in the ProcessInput method. The PipelineBuffer received in this method is an Input buffer and contains the rows that were added to by upstream components. This buffer is restricted and cannot be used to add or remove rows from the buffer.

The PipelineBuffer is written in managed code and supports managed data flow component developers by marshalling data between managed code and the underlying IDTSBuffer100 COM object.

For a complete list of Integration Services data types and the corresponding Get and Set methods of the PipelineBuffer class to use with each data type, see Utilisation de types de données dans le flux de données.

Exemples

The following example shows a transformation component that iterates the rows and columns of a PipelineBuffer in ProcessInput.

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


namespace Microsoft.Samples.SqlServer.Dts
{
   [DtsPipelineComponent
   (
   DisplayName="SampleComponent",
   ComponentType=ComponentType.Transform
   )]
   public class SampleComponent: PipelineComponent
   {
      public override void ProvideComponentProperties()
      {
         base.ProvideComponentProperties();

         ///Name the input and output add by the base class.
         ComponentMetaData.InputCollection[0].Name = "SampleInput";
         ComponentMetaData.OutputCollection[0].Name = "SampleOutput";
      }

      public override void ProcessInput(int inputID, PipelineBuffer buffer)
      {

      IDTSInput100 input = ComponentMetaData.InputCollection.GetObjectByID(inputID);

      while (buffer.NextRow())
      {
         foreach (IDTSInputColumn100 col in input.InputColumnCollection)
         {
            int colIndex = BufferManager.FindColumnByLineageID(input.Buffer,col.LineageID);
            object colData = buffer[colIndex];
            //TODO: Do something with the column data.
         }
      }
      }
   }
}

The following example shows a source component that adds rows to the output buffer in PrimeOutput.

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


namespace Microsoft.Samples.SqlServer.Dts
{
   [DtsPipelineComponent
   (
      DisplayName="SampleComponent",
      ComponentType=ComponentType.SourceComponent
)]
   public class SampleComponent: PipelineComponent
   {
      public override void PrimeOutput(int outputs, int[] outputIDs,PipelineBuffer[] buffers)
      {
         int rows = 100;
         PipelineBuffer buf = buffers[0];
         IDTSOutput100 output = ComponentMetaData.OutputCollection[0];
         Random rand = new Random();

         //Loop rows number of times
         for(int r = 0; r < rows; r++)
         {
            buf.AddRow();
            foreach( IDTSOutputColumn100 col in output.OutputColumnCollection)
            {
               int colIndex = BufferManager.FindColumnByLineageID( output.Buffer, col.LineageID);
               // Note, buffer columns containing binary large objects
               // can not be set using the following syntax. Instead,
               // the AddBlobData and SetBytes methods are used.
               buf[colIndex] = rand.Next();
            }
         }
         buf.SetEndOfRowset();
      }
   }
}

Sécurité des threads

Tous les membres publics static (Shared dans Visual Basic) de ce type sont thread-safe. Tous les membres de l'instance ne sont pas garantis comme étant thread-safe.

Voir aussi

Référence

Espace de noms Microsoft.SqlServer.Dts.Pipeline