PipelineBuffer.GetBlobData(Int32, Int32, Int32) Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Recupera uma matriz de bytes de um BLOB (objeto binário grande) armazenado em uma coluna PipelineBuffer.
public:
cli::array <System::Byte> ^ GetBlobData(int columnIndex, int offset, int count);
public byte[] GetBlobData (int columnIndex, int offset, int count);
member this.GetBlobData : int * int * int -> byte[]
Public Function GetBlobData (columnIndex As Integer, offset As Integer, count As Integer) As Byte()
Parâmetros
- columnIndex
- Int32
O índice da coluna que contém o BLOB.
- offset
- Int32
O ponto no BLOB para começar a recuperar bytes do BLOB.
- count
- Int32
O número de bytes a serem recuperados do BLOB.
Retornos
A matriz de bytes na coluna PipelineBuffer.
Exemplos
O exemplo a seguir recupera toda a matriz de bytes de uma PipelineBuffer coluna.
public override void ProcessInput(int inputID, PipelineBuffer buffer)
{
IDTSInput100 input = ComponentMetaData.InputCollection.GetObjectByID(inputID);
foreach (IDTSInputColumn100 col in input.InputColumnCollection)
{
int index = BufferManager.FindColumnByLineageID(input.Buffer, col.LineageID);
BufferColumn bc = buffer.GetColumnInfo(index);
if (bc.DataType == DataType.DT_IMAGE)
{
uint blobLength = buffer.GetBlobLength(index);
byte [] blobBytes = buffer.GetBlobData(index, 0, (int)blobLength);
//TODO: Do something with the blob data.
}
}
}
Public Overrides Sub ProcessInput(ByVal inputID As Integer, ByVal buffer As PipelineBuffer)
Dim input As IDTSInput100 = ComponentMetaData.InputCollection.GetObjectByID(inputID)
For Each col As IDTSInputColumn100 In input.InputColumnCollection
Dim index As Integer = BufferManager.FindColumnByLineageID(input.Buffer, col.LineageID)
Dim bc As BufferColumn = buffer.GetColumnInfo(index)
If bc.DataType = DataType.DT_IMAGE Then
Dim blobLength As System.UInt32 = buffer.GetBlobLength(index)
Dim blobBytes As Byte() = buffer.GetBlobData(index, 0, CType(blobLength, Integer))
'TODO: Do something with the blob data
End If
Next
End Sub
Comentários
Esse método funciona com os seguintes tipos de dados do Integration Services:
Ao recuperar dados de PipelineBuffer colunas que contêm um BLOB, como um DT_IMAGE, especifique o local inicial no BLOB com o offset
parâmetro e o número de bytes a serem recuperados no count
parâmetro.
Para obter uma lista completa de tipos de dados do Integration Services e os métodos correspondentes Get
e Set
da PipelineBuffer classe a serem usados com cada tipo, consulte Trabalhando com tipos de dados no Fluxo de Dados.