Propósito

✔ Programação GLOBAL® - Quaisquer soluções e/ou desenvolvimento de aplicações pessoais, ou da empresa, que não constem neste Blog devem ser tratados como consultoria freelance. Queiram contatar-nos: brazilsalesforceeffectiveness@gmail.com | ESTE BLOG NÃO SE RESPONSABILIZA POR QUAISQUER DANOS PROVENIENTES DO USO DOS CÓDIGOS AQUI POSTADOS EM APLICAÇÕES PESSOAIS OU DE TERCEIROS.

MS Access | Código VBA para Backup de Todas as Tabelas Comentado

MS Access | Código VBA para Backup de Todas as Tabelas Comentado

O código VBA abaixo é uma solução robusta para automatizar a tarefa de criar backups de tabelas em um banco de dados Access, garantindo a segurança e a integridade dos dados. Em cenários onde bases de dados são frequentemente atualizadas, o backup periódico torna-se essencial para evitar perda de informações críticas. Vamos explorar as funcionalidades e a aplicabilidade deste código.


Sub BackupTabelasAccessAvancado()


    ' Declaração de variáveis

    Dim db As DAO.Database

    Dim tdf As DAO.TableDef

    Dim nomeTabela As String

    Dim caminhoBackup As String

    Dim dbBackup As DAO.Database

    Dim backupNomeArquivo As String

    Dim dataHora As String

    Dim fso As Object


    On Error GoTo TrataErro  ' Ativa o tratamento de erro


    ' Define o caminho para salvar o arquivo de backup

    Let caminhoBackup = "C:\Users\andre.bernardes\Access_BKPs\"

    

    ' Verifica se o diretório de backup existe, se não, cria-o

    Set fso = CreateObject("Scripting.FileSystemObject")

    If Not fso.FolderExists(caminhoBackup) Then

        fso.CreateFolder (caminhoBackup)  ' Cria o diretório caso ele não exista

    End If


    ' Formata a data e hora atual para usar no nome do arquivo de backup

    Let dataHora = Format(Now, "ddmmyyyyhhmmss") & "AndréLuizBernardes"


    ' Define o nome do arquivo de backup com base na data e hora atuais

    Let backupNomeArquivo = caminhoBackup & "BKP_Access_" & dataHora & ".accdb"

    Debug.Print backupNomeArquivo  ' Exibe o caminho do backup no console


    ' Abre o banco de dados atual

    Set db = CurrentDb


    ' Cria um novo banco de dados para o backup

    Set dbBackup = DBEngine.CreateDatabase(backupNomeArquivo, dbLangGeneral)


    ' Registra o início do backup em uma tabela de log

    Call RegistraLog(db, "Início do backup", backupNomeArquivo)


    ' Percorre todas as tabelas no banco de dados atual

    For Each tdf In db.TableDefs

        Let nomeTabela = tdf.Name

        

        ' Ignora as tabelas de sistema (começam com "MSys")

        If Left(nomeTabela, 4) <> "MSys" Then

            ' Copia a tabela para o banco de dados de backup

            dbBackup.Execute "SELECT * INTO [" & nomeTabela & "] FROM [" & nomeTabela & "]"

        End If

    Next tdf


    ' Fecha o banco de dados de backup

    dbBackup.Close


    ' Registra a conclusão do backup em uma tabela de log

    Call RegistraLogS(db, "Backup concluído", backupNomeArquivo)


    ' Limpeza de variáveis

    Set tdf = Nothing

    Set dbBackup = Nothing

    Set db = Nothing

    Set fso = Nothing


    MsgBox "Backup completo. Arquivo salvo em: " & backupNomeArquivo  ' Exibe uma mensagem confirmando o backup


    Exit Sub


TrataErro:

    ' Registra o erro em uma tabela de log

    Call RegistraLogS(db, "Erro durante o backup", Err.Description)

    MsgBox "Ocorreu um erro: " & Err.Description, vbCritical  ' Exibe uma mensagem de erro


End Sub

 


Primeiramente, a automação de backups reduz significativamente a dependência de ações manuais, que são propensas a erros e podem ser negligenciadas. Neste código, as tabelas de dados são copiadas automaticamente para um novo banco de dados criado no momento da execução, com um nome gerado a partir da data e hora. Isso permite um controle eficiente sobre o histórico de backups, facilitando a restauração de versões anteriores quando necessário.


Além disso, o uso de tabelas de log para registrar eventos como o início e o término do backup é uma prática recomendada para auditoria e acompanhamento de processos críticos. O Código VBA possibilita a criação de um histórico detalhado de operações, essencial para análise de performance e identificação de problemas, garantindo maior transparência no processo.


 Que tal aprender estes códigos também: 

MS Access | Aplicando Função Concatenação de Valores nos Campos das Consultas
MS Access | Utilizando SendKeys de Forma Eficiente
MS Access | Automatizando a Compactação do Bancos de Dados
MS Access | Como Gerenciar Links das Tabelas
MS Access | Quebra de Texto em Linhas com Comprimento Máximo
MS Access | Monitoramento de Conexões de Usuários
MS Access | Mapeando 3.500 Erros com a Criação de Tabelas de Erros
MS Access | Código para Registro de Logs
MS Access | 17 Passos Essenciais para Melhorar seu Código VBA
MS Access | Código VBA para Backup de Todas as Tabelas Comentado


Código VBA é também adaptável a diferentes estruturas de banco de dados. Ele ignora tabelas de sistema, garantindo que apenas as tabelas relevantes sejam copiadas para o backup, o que torna o processo mais eficiente e otimizado. A flexibilidade para customizar o caminho de salvamento dos arquivos é outra característica útil, permitindo a definição de diretórios específicos para armazenamento dos backups.


Por fim, o Código VBA incorpora mecanismos de tratamento de erros, assegurando que qualquer falha seja registrada e comunicada ao usuário de forma clara. Isso é essencial em ambientes corporativos, onde a integridade dos dados não pode ser comprometida e ações corretivas precisam ser rápidas. A geração de mensagens de erro e o registro detalhado permitem a identificação rápida da causa de problemas durante o processo de backup.


A implementação deste código em processos de rotina de bancos de dados Access contribui para a eficiência, segurança e confiabilidade das operações, tornando-o uma ferramenta valiosa em ambientes onde a continuidade de dados é essencial, como em análises de planejamento de visitas e gestão de informações estratégicas.


  Clique aqui e nos contate via What's App para avaliarmos seus projetos 

Envie seus comentários e sugestões e compartilhe este artigo!
brazilsalesforceeffectiveness@gmail.com


 Série Donut Project 
DONUT PROJECT: VBA - Projetos e Códigos de Visual Basic for Applications (Visual Basic For Apllication)eBook - DONUT PROJECT 2024 - Volume 03 - Funções Financeiras - André Luiz Bernardes eBook - DONUT PROJECT 2024 - Volume 02 - Conectando Banco de Dados - André Luiz Bernardes eBook - DONUT PROJECT 2024 - Volume 01 - André Luiz Bernardes


 Clique nas capas abaixo e compre também: 

DONUT PROJECT: VBA - Projetos e Códigos de Visual Basic for Applications (Visual Basic For Apllication)


Série Top 10 Funções: Top 10 Funções VBA para o Microsoft Excel (Série Top 10 Funções - Microsoft Excel)


eBook - DONUT PROJECT 2024 - Volume 03 - Funções Financeiras - André Luiz Bernardes

eBook - DONUT PROJECT 2024 - Volume 02 - Conectando Banco de Dados - André Luiz Bernardes

eBook - DONUT PROJECT 2024 - Volume 01 - André Luiz Bernardes

Nenhum comentário:

Postar um comentário

diHITT - Notícias