Executar uma carga incremental de várias tabelas
No tópico Melhorando cargas incrementais com o Change Data Capture, o diagrama ilustra um pacote básico que executa uma carga incremental em apenas uma tabela. No entanto, carregar uma tabela não é tão comum quanto ter que realizar uma carga incremental de diversas tabelas.
Ao executar uma carga incremental de diversas tabelas, algumas etapas devem ser realizadas uma vez para todas as tabelas e outras etapas devem ser repetidas para cada tabela de origem. Você tem mais de uma opção para implementar estas etapas no Integration Services:
Usar um pacote pai e pacotes filho.
Usar diversas tarefas de Fluxo de Dados em um único pacote.
Carregando diversas tabelas usando um pacote pai e diversos pacotes filho
É possível usar um pacote pai para executar essas etapas que só precisam ser executadas uma vez. Os pacotes filho executarão essas etapas que precisam ser executadas para cada tabela de origem.
Para criar um pacote pai que executa essas etapas que só precisam ser executadas uma vez
Crie um pacote pai.
No fluxo de controle, use uma tarefa Executar SQL ou expressões do Integration Services para calcular os pontos de extremidade.
Para obter um exemplo de como calcular os pontos de extremidade, consulte Especificar um intervalo de dados de alteração.
Se necessário, use um contêiner Loop For para atrasar a execução até que os dados de alteração para o período selecionado estejam prontos.
Para obter um exemplo de contêiner de Loop For, consulte Determinar se os dados de alteração estão prontos.
Use diversas tarefas Executar Pacote para executar pacotes filho para cada tabela a ser carregada. Passe os pontos de extremidade calculados no pacote pai para cada pacote filho usando as Configurações de Variáveis do Pacote Pai.
Para obter mais informações, consulte Tarefa Executar Pacote e Usar os valores de variáveis e parâmetros em um pacote filho.
Para criar pacotes filho para executar as etapas que precisam ser executadas para cada tabela de origem
Para cada tabela de origem, crie um pacote filho.
No fluxo de controle, use uma tarefa Script ou Executar SQL para montar a instrução SQL que será usada para consultar a existência de alterações.
Para obter um exemplo de como montar a consulta, consulte Preparar para consultar os dados de alteração.
Use uma tarefa de Fluxo de Dados simples em cada pacote filho para carregar os dados de alteração e aplicá-los no destino. Configure o Fluxo de Dados conforme descrito nas seguintes etapas:
No fluxo de dados, use um componente de origem para consultar as tabelas de alterações para as alterações que caem dentro dos pontos de extremidade selecionados.
Para obter um exemplo de como consultar as tabelas de alteração, consulte Recuperar e compreender os dados de alteração.
Use uma transformação de Divisão Condicional para direcionar as inserções, atualizações e exclusões para saídas diferentes para o processamento apropriado.
Para obter um exemplo de como configurar esta transformação para direcionar a saída, consulte Processar inserções, atualizações e exclusões.
Use um componente de destino para aplicar as inserções ao destino. Use as transformações de Comando OLE DB com as instruções UPDATE e DELETE com parâmetros para aplicar atualizações e exclusões ao destino.
Para obter um exemplo de como usar essa transformação para aplicar atualizações e exclusões, consulte Aplicar as alterações ao destino.
Carregando diversas tabelas usando diversas tarefas de Fluxo de Dados em um único pacote
Como alternativa, é possível usar um único pacote que contém uma tarefa de Fluxo de Dados separado para cada tabela de origem que será carregada.
Para carregar diversas tabelas usando diversas tarefas de Fluxo de Dados em um único pacote
Crie um único pacote.
No fluxo de controle, use uma tarefa Executar SQL ou expressões do Integration Services para calcular os pontos de extremidade.
Para obter um exemplo de como calcular os pontos de extremidade, consulte Especificar um intervalo de dados de alteração.
Se necessário, use um contêiner Loop For para atrasar a execução até que os dados de alteração para o intervalo selecionado estejam prontos.
Para obter um exemplo de contêiner de Loop For, consulte Determinar se os dados de alteração estão prontos.
Use uma tarefa Script ou Executar SQL para montar a instrução SQL que será usada para consultar a existência de alterações.
Para obter um exemplo de como montar a consulta, consulte Preparar para consultar os dados de alteração.
Use diversas tarefas de Fluxo de Dados para carregar os dados de alteração de cada tabela de origem e aplicá-los no destino. Configure cada tarefa de Fluxo de Dados conforme descrito nas seguintes etapas.
Em cada fluxo de dados, use um componente de origem para consultar as tabelas de alterações para as alterações que caem dentro dos pontos de extremidade selecionados.
Para obter um exemplo de como consultar as tabelas de alteração, consulte Recuperar e compreender os dados de alteração.
Use uma transformação de Divisão Condicional para direcionar as inserções, atualizações e exclusões para saídas diferentes para o processamento apropriado.
Para obter um exemplo de como configurar esta transformação para direcionar a saída, consulte Processar inserções, atualizações e exclusões.
Use um componente de destino para aplicar as inserções ao destino. Use as transformações de Comando OLE DB com as instruções UPDATE e DELETE com parâmetros para aplicar atualizações e exclusões ao destino.
Para obter um exemplo de como usar essa transformação para aplicar atualizações e exclusões, consulte Aplicar as alterações ao destino.
|