BufferManager プロパティ
パイプライン コンポーネントの IDTSBufferManager100 を取得します。
この API は、CLS に準拠していません。
名前空間: Microsoft.SqlServer.Dts.Pipeline
アセンブリ: Microsoft.SqlServer.PipelineHost (Microsoft.SqlServer.PipelineHost.dll)
構文
'宣言
<CLSCompliantAttribute(False)> _
Public ReadOnly Property BufferManager As IDTSBufferManager100
Get
'使用
Dim instance As PipelineComponent
Dim value As IDTSBufferManager100
value = instance.BufferManager
[CLSCompliantAttribute(false)]
public IDTSBufferManager100 BufferManager { get; }
[CLSCompliantAttribute(false)]
public:
property IDTSBufferManager100^ BufferManager {
IDTSBufferManager100^ get ();
}
[<CLSCompliantAttribute(false)>]
member BufferManager : IDTSBufferManager100
function get BufferManager () : IDTSBufferManager100
説明
BufferManager は、PreExecute メソッドのコンポーネントで最初に利用可能な読み取り専用の実行時プロパティです。
FindColumnByLineageID メソッドは、PipelineBuffer 内で、コンポーネントの IDTSInputColumnCollection100 または IDTSOutputColumnCollection100 内のコンポーネント列を検索するために使用されます。PipelineBuffer に含まれる列の数はコンポーネントで予測した列の数より多い場合があるため、このメソッドが必要です。
また、BufferManager は、CreateBuffer、CreateFlatBuffer、CreateVirtualBuffer の各メソッドを使用して新しい IDTSBuffer100 オブジェクトを作成するためにも使用されます。ただし、これらのメソッドはマネージ コードではサポートされず、ネイティブ C++ コンポーネントを記述するときにのみ使用されます。
使用例
次のコード例は、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