Usar um destino do conjunto de registros
O destino do Conjunto de Registros não salva dados em uma fonte de dados externa. Em vez disso, o destino do Conjunto de Registros salva dados na memória em um conjunto de registros armazenado em uma variável de pacote do Integration Services do tipo de dados Object. Depois que o destino do Conjunto de Registros salva os dados, geralmente você usa um contêiner Loop Foreach com o enumerador ADO Foreach para processar uma linha do conjunto de registros de cada vez. O enumerador ADO Foreach salva o valor de cada coluna da linha atual em uma variável de pacote separada. Em seguida, as tarefas que você configura dentro do contêiner Loop Foreach leem esses valores das variáveis e executam alguma ação com eles.
Você pode usar o destino do Conjunto de Registros em muitos cenários diferentes. Veja alguns exemplos:
É possível usar uma tarefa Enviar Email e a linguagem da expressão do Integration Services para enviar uma mensagem de email personalizada para cada linha no conjunto de registros.
Você pode usar um componente Script configurado como fonte, dentro de uma tarefa de fluxo de dados, para ler os valores nas colunas do fluxo de dados. Em seguida, é possível usar transformações e destinos para transformar e salvar a linha. Neste exemplo, a tarefa de fluxo de dados é executada uma vez para cada linha.
As seções a seguir primeiro descrevem o processo geral de uso do destino do Conjunto de Registros e depois mostram um exemplo específico de como utilizar o destino.
Etapas gerais para o uso de um destino do conjunto de registros
O procedimento a seguir resume as etapas necessárias para salvar dados em um destino do Conjunto de Registros e usar o contêiner Loop Foreach para processar cada linha.
Para salvar dados em um destino do Conjunto de Registros e processar cada linha usando o contêiner Loop Foreach
No SSDT (SQL Server Data Tools), crie ou abra um pacote do Integration Services.
Crie uma variável que conterá o conjunto de registros salvo na memória pelo destino do Conjunto de Registros e defina o tipo de variável como Object.
Crie mais variáveis dos tipos apropriados para conter os valores de cada coluna no conjunto de registros que você deseja usar.
Adicione e configure o gerenciador de conexões necessário para a fonte de dados que você planeja usar no fluxo de dados.
Adicione uma tarefa de fluxo de dados ao pacote e, na guia Fluxo de Dados do SSIS Designer, configure fontes e transformações para carregar e transformar os dados.
Adicione um destino do Conjunto de Registros ao fluxo de dados e conecte-o às transformações. Para a propriedade VariableName do destino do Conjunto de Registros, insira o nome da variável criada para conter o conjunto de registros.
Na guia Fluxo de Controle do SSIS Designer, adicione um contêiner Loop Foreach e conecte esse contêiner após a tarefa de fluxo de dados. Em seguida, abra o Editor de Loop Foreach para definir o contêiner com as seguintes configurações:
Na página Coleção, selecione o Enumerador ADO Foreach. Em seguida, para Variável de origem do objeto ADO, selecione a variável que contém o conjunto de registros.
Na página Mapeamentos de Variáveis, mapeie o índice com base em zero de cada coluna que você deseja usar para a variável apropriada.
Em cada iteração do loop, o enumerador popula essas variáveis com os valores de coluna da linha atual.
Dentro do contêiner Loop Foreach, adicione e configure tarefas para processar uma linha do conjunto de registros de cada vez, lendo os valores das variáveis.
Exemplo de uso do destino do Conjunto de Registros
No exemplo a seguir, a tarefa de fluxo de dados carrega informações sobre os funcionários de AdventureWorks2012 da tabela Sales.SalesPerson em um destino Conjunto de Registros. Em seguida, um contêiner Loop Foreach lê uma linha de dados de cada vez e chama uma tarefa Enviar Email. A tarefa Enviar Email usa expressões para enviar uma mensagem de email personalizada a cada vendedor sobre o valor de seu bônus.
Para criar o projeto e configurar as variáveis
No SQL Server Data Tools, crie um novo projeto do Integration Services.
No menu SSIS, selecione Variáveis.
Na janela Variáveis, crie as variáveis que conterão o conjunto de registros e os valores de coluna da linha atual:
Crie uma variável denominada BonusRecordset e defina seu tipo como Object.
A variável BonusRecordset contém o conjunto de registros.
Crie uma variável denominada EmailAddress e defina seu tipo como String.
A variável EmailAddress contém o endereço de email do vendedor.
Crie uma variável denominada FirstName e defina seu tipo como String.
A variável FirstName contém o nome do vendedor.
Crie uma variável denominada Bonus e defina seu tipo como Double.
A variável Bonus contém o valor do bônus do vendedor.
Para configurar os gerenciadores de conexões
Na área Gerenciadores de Conexões do SSIS Designer, adicione e configure um novo gerenciador de conexões OLE DB que se conecta ao banco de dados de exemplo AdventureWorks2012.
A fonte OLE DB na tarefa de fluxo de dados usará esse gerenciador de conexões para recuperar dados.
Na área Gerenciadores de Conexões, adicione e configure um novo gerenciador de conexões SMTP que se conecta ao servidor SMTP disponível.
A tarefa Enviar Email dentro do contêiner Loop Foreach usará esse gerenciador de conexões para enviar emails.
Para configurar o fluxo de dados e o destino do Conjunto de Registros
Na guia Fluxo de Controle do SSIS Designer, adicione uma tarefa de fluxo de dados à superfície de design.
Na guia Fluxo de Dados, adicione uma fonte OLE DB à tarefa de fluxo de dados e abra o Editor de Origem OLE DB.
Na página Gerenciador de Conexões do editor, defina a fonte com as seguintes configurações:
Para Gerenciador de Conexões OLE DB, selecione o gerenciador de conexões OLE DB criado anteriormente.
Para Modo de acesso a dados, selecione o Comando SQL.
Em Texto do comando SQL, digite a seguinte consulta:
SELECT Person.Contact.EmailAddress, Person.Contact.FirstName, CONVERT(float, Sales.SalesPerson.Bonus) AS Bonus FROM Sales.SalesPerson INNER JOIN Person.Contact ON Sales.SalesPerson.SalesPersonID = Person.Contact.ContactID
Observação É necessário converter o valor currency na coluna Bonus em um float antes de carregar esse valor em uma variável de pacote cujo tipo é Double.
Na guia Fluxo de Dados, adicione um destino do Conjunto de Registros e conecte o destino após a fonte OLE DB.
Abra o Editor de Destino do Conjunto de Registros e defina o destino com as seguintes configurações:
Na guia Propriedades do Componente, para a propriedade VariableName, selecione User::BonusRecordset.
Na guia Colunas de Entrada, selecione todas as três colunas disponíveis.
Para configurar o contêiner Loop Foreach e executar o pacote
Na guia Fluxo de Controle do SSIS Designer, adicione um contêiner Loop Foreach e conecte esse contêiner após a tarefa de fluxo de dados.
Abra o Editor de Loop Foreach e defina o contêiner com as seguintes configurações:
Na página Coleção, para Enumerador, selecione Enumerador ADO Foreach e, para Variável de origem do objeto ADO, selecione User::BonusRecordset.
Na página Mapeamentos de Variáveis, mapeia User::EmailAddress para índice 0, User::FirstName para índice 1 e User::Bonus para índice 2.
Na guia Fluxo de Controle, dentro do contêiner Loop Foreach, adicione uma tarefa Enviar Email.
Abra o Editor da Tarefa Enviar Email e, na página Email, defina a tarefa com as seguintes configurações:
Para SmtpConnection, selecione o gerenciador de conexões SMTP configurado anteriormente.
Em De, insira um endereço de email apropriado.
Se você usar seu próprio endereço de email, poderá confirmar a execução bem-sucedida do pacote. Você receberá recibos de impossibilidade de entrega das mensagens enviadas pela tarefa Enviar Email aos vendedores fictícios de AdventureWorks2012.
Em Para, insira um endereço de email padrão.
Esse valor não será usado, mas será substituído em tempo de execução pelo endereço de email de cada vendedor.
Em Assunto, digite "Seu bônus anual".
Em MessageSourceType, selecione Entrada Direta.
Na página Expressões do Editor da Tarefa Enviar Email, clique no botão de reticências (...) para abrir o Editor de Expressões de Propriedade.
No Editor de Expressões de Propriedade, insira as seguintes informações:
Em ToLine, adicione a seguinte expressão:
@[User::EmailAddress]
Para a propriedade MessageSource, adicione a seguinte expressão:
"Dear " + @[User::FirstName] + ": The amount of your bonus for this year is $" + (DT_WSTR, 12) @[User::Bonus] + ". Thank you!"
Execute o pacote.
Caso tenha especificado um servidor SMTP válido e fornecido seu próprio endereço de email, você receberá recibos de impossibilidade de entrega que a tarefa Enviar Email envia aos vendedores fictícios de AdventureWorks2012.