Entrar com a conta da Microsoft
Entrar ou criar uma conta.
Olá,
Selecionar uma conta diferente.
Você tem várias contas
Escolha a conta com a qual você deseja entrar.
Migrar um banco de dados do Access para o SQL Server

Todos nós temos limites e um banco de dados access não é exceção. Por exemplo, um banco de dados access tem um limite de tamanho de 2 GB e não pode dar suporte a mais de 255 usuários simultâneos. Portanto, quando for a hora do banco de dados access ir para o próximo nível, você pode migrar para SQL Server. SQL Server (local ou na nuvem do Azure) dá suporte a quantidades maiores de dados, usuários mais simultâneos e tem maior capacidade do que o mecanismo de banco de dados JET/ACE. Este guia oferece um bom início à sua jornada de SQL Server, ajuda a preservar as soluções front-end do Access que você criou e, com sorte, motiva você a usar o Access para futuras soluções de banco de dados. O Assistente de Upsizing foi removido do Access no Access 2013, portanto, agora você pode usar o SSMA (Assistente de Migração do Microsoft SQL Server). Para migrar com êxito, siga esses estágios.

Os estágios da migração de banco de dados para SQL Server

Antes de começar

As seções a seguir fornecem informações em segundo plano e outras informações para ajudá-lo a começar.

Sobre bancos de dados divididos

Todos os objetos de banco de dados do Access podem estar em um arquivo de banco de dados ou podem ser armazenados em dois arquivos de banco de dados: um banco de dados front-end e um banco de dados de back-end. Isso é chamado de divisão do banco de dados e é projetado para facilitar o compartilhamento em um ambiente de rede. O arquivo de banco de dados de back-end deve conter apenas tabelas e relações. O arquivo front-end deve conter apenas todos os outros objetos, incluindo formulários, relatórios, consultas, macros, módulos VBA e tabelas vinculadas ao banco de dados back-end. Quando você migra um banco de dados access, ele é semelhante a um banco de dados dividido nesse SQL Server está agindo como um novo back-end para os dados que agora estão localizados em um servidor.

Como resultado, você ainda pode manter o banco de dados de acesso front-end com tabelas vinculadas às tabelas SQL Server. Efetivamente, você pode derivar os benefícios do rápido desenvolvimento de aplicativos que um banco de dados access fornece, juntamente com a escalabilidade de SQL Server.

SQL Server benefícios

Ainda precisa de algum convencimento para migrar para SQL Server? Aqui estão alguns benefícios adicionais para pensar:

  • Usuários mais simultâneos    SQL Server pode lidar com muitos usuários mais simultâneos do que o Access e minimiza os requisitos de memória quando mais usuários são adicionados.

  • Maior disponibilidade    Com SQL Server, você pode fazer backup dinâmico, incremental ou completo, do banco de dados enquanto ele estiver em uso. Consequentemente, não é necessário obrigar os usuários a sair do banco de dados para fazer backup dos dados.

  • Alto desempenho e escalabilidade    O banco de dados SQL Server geralmente tem um desempenho melhor do que um banco de dados access, especialmente com um banco de dados grande e do tamanho de terabyte. Além disso, SQL Server processa consultas de forma muito mais rápida e eficiente processando consultas em paralelo, usando vários threads nativos em um único processo para lidar com solicitações de usuário.

  • Segurança aprimorada    Usando uma conexão confiável, SQL Server se integra à segurança do sistema Windows para fornecer um único acesso integrado à rede e ao banco de dados, empregando o melhor dos dois sistemas de segurança. Isso torna muito mais fácil administrar esquemas de segurança complexos. SQL Server é o armazenamento ideal para informações confidenciais, como números da Previdência Social, dados de cartão de crédito e endereços confidenciais.

  • Recuperabilidade imediata     Se o sistema operacional falhar ou a energia acabar, SQL Server poderá recuperar automaticamente o banco de dados para um estado consistente em questão de minutos e sem intervenção de administrador de banco de dados.

  • Uso de VPN    O Acesso e a VPN (Redes Virtuais Privadas) não se dão bem. Mas com SQL Server, os usuários remotos ainda podem usar o banco de dados front-end access em uma área de trabalho e o SQL Server back-end localizado atrás do firewall VPN.

  • SQL do Azure    Além dos benefícios do SQL Server, oferece escalabilidade dinâmica sem tempo de inatividade, otimização inteligente, escalabilidade e disponibilidade globais, eliminação de custos de hardware e administração reduzida.

Escolha a melhor opção SQL do Azure Servidor

Se você estiver migrando para SQL do Azure Server, há três opções para escolher, cada uma com benefícios diferentes:

  • Banco de dados único/pools elásticos    Essa opção tem seu próprio conjunto de recursos gerenciados por meio de um servidor Banco de Dados SQL. Um único banco de dados é como um banco de dados contido no SQL Server. Você também pode adicionar um pool elástico, que é uma coleção de bancos de dados com um conjunto compartilhado de recursos gerenciados por meio do servidor Banco de Dados SQL. Os recursos de SQL Server mais usados estão disponíveis com backups internos, patching e recuperação. Mas não há tempo de manutenção exato garantido e a migração de SQL Server pode ser difícil.

  • Instância gerenciada    Essa opção é uma coleção de bancos de dados do sistema e do usuário com um conjunto compartilhado de recursos. Uma instância gerenciada é como uma instância do banco de dados SQL Server altamente compatibilidade com SQL Server local. Uma instância gerenciada tem backups internos, patching, recuperação e é fácil migrar de SQL Server. No entanto, há um pequeno número de recursos SQL Server que não estão disponíveis e nenhum tempo de manutenção exato garantido.

  • Máquina Virtual Azure    Essa opção permite que você execute SQL Server dentro de uma máquina virtual na nuvem do Azure. Você tem controle total sobre o mecanismo SQL Server e um caminho de migração fácil. Mas você precisa gerenciar seus backups, patches e recuperação.

Para obter mais informações, confira Escolhendo seu caminho de migração de banco de dados para o Azure e O que é SQL do Azure?.

Primeiras etapas

Há alguns problemas que você pode resolver antecipadamente que podem ajudar a simplificar o processo de migração antes de executar o SSMA:

  • Adicionar índices de tabela e chaves primárias    Verifique se cada tabela access tem um índice e uma chave primária. SQL Server requer que todas as tabelas tenham pelo menos um índice e exige que uma tabela vinculada tenha uma chave primária se a tabela puder ser atualizada.

  • Verificar relações de chave primária/estrangeira    Verifique se essas relações são baseadas em campos com tipos e tamanhos de dados consistentes. SQL Server não dá suporte a colunas unidas com diferentes tipos de dados e tamanhos em restrições de chave estrangeira.

  • Remover a coluna Anexo    O SSMA não migra tabelas que contêm a coluna Anexo.

Antes de executar o SSMA, siga as primeiras etapas a seguir.

  1. Feche o banco de dados access.

  2. Verifique se os usuários atuais conectados ao banco de dados também fecham o banco de dados.

  3. Se o banco de dados estiver em .mdb formato de arquivo, remova a segurança no nível do usuário.

  4. Faça backup do banco de dados. Para obter mais informações, consulte Proteger seus dados com processos de backup e restauração.

Dica    Considere instalar Microsoft SQL Server Express edição em sua área de trabalho que dá suporte a até 10 GB e é uma maneira gratuita e mais fácil de executar e marcar sua migração. Ao se conectar, use LocalDB como a instância do banco de dados.

Dica    Se possível, use uma versão autônoma do Access. Se você só puder usar Microsoft 365, use o mecanismo de banco de dados access 2010 para migrar seu banco de dados access ao usar o SSMA. Para obter mais informações, confira Mecanismo de Banco de Dados do Microsoft Access 2010 Redistribuível.

Executar o SSMA

A Microsoft fornece Assistente de Migração do Microsoft SQL Server (SSMA) para facilitar a migração. O SSMA migra principalmente tabelas e seleciona consultas sem parâmetros. Formulários, relatórios, macros e módulos VBA não são convertidos. O Explorer de metadados SQL Server exibe objetos e objetos de SQL Server de banco de dados do Access, permitindo que você examine o conteúdo atual de ambos os bancos de dados. Essas duas conexões são salvas em seu arquivo de migração caso você decida transferir objetos adicionais no futuro.

Observação    O processo de migração pode levar algum tempo dependendo do tamanho dos objetos de banco de dados e da quantidade de dados que devem ser transferidos.

  1. Para migrar um banco de dados usando o SSMA, primeiro baixe e instale o software clicando duas vezes no arquivo MSI baixado. Instale a versão apropriada de 32 ou 64 bits para seu computador.

  2. Depois de instalar o SSMA, abra-o na área de trabalho, preferencialmente do computador com o arquivo de banco de dados Access.

    Você também pode abri-lo em um computador que tenha acesso ao banco de dados access da rede em uma pasta compartilhada.

  3. Siga as instruções inicio no SSMA para fornecer informações básicas, como o local SQL Server, o banco de dados access e objetos para migrar, informações de conexão e se você deseja criar tabelas vinculadas.

  4. Se você estiver migrando para SQL Server 2016 ou posterior e quiser atualizar uma tabela vinculada, adicione uma coluna de rowversion selecionando Revisão Ferramentas > Configurações do Projeto > Geral.

    O campo rowversion ajuda a evitar conflitos de registro. O Access usa esse campo de rowversion em um SQL Server tabela vinculada para determinar quando o registro foi atualizado pela última vez. Além disso, se você adicionar o campo rowversion a uma consulta, o Access o usará para selecionar novamente a linha após uma operação de atualização. Isso melhora a eficiência ajudando a evitar erros de conflito de gravação e cenários de exclusão de registro que podem acontecer quando o Access detecta resultados diferentes do envio original, como pode ocorrer com tipos de dados de número de ponto flutuante e gatilhos que modificam colunas. No entanto, evite usar o campo rowversion em formulários, relatórios ou código VBA. Para obter mais informações, consulte rowversion.

    Observação    Evite a inversão de linha confusa com carimbos de data/hora. Embora o carimbo de data/hora palavra-chave seja um sinônimo de inversão de linha em SQL Server, você não pode usar a rowversion como uma maneira de carimbo de data/hora de uma entrada de dados.

  5. Para definir tipos de dados precisos , selecione Revisar Ferramentas > Configurações do Projeto > Mapeamento de Tipos. Por exemplo, se você armazenar apenas o texto em inglês, poderá usar o tipo de dados varchar em vez de nvarchar .

Converter objetos

O SSMA converte objetos Access em objetos SQL Server, mas não copia os objetos imediatamente. O SSMA fornece uma lista dos seguintes objetos a serem migrados para que você possa decidir se deseja movê-los para SQL Server banco de dados:

  • Tabelas e colunas

  • Selecione Consultas sem parâmetros.

  • Chaves primárias e estrangeiras

  • Índices e valores padrão

  • Verificar restrições (permitir propriedade de coluna de comprimento zero, regra de validação de coluna, validação de tabela)

Como prática recomendada, use o relatório de avaliação do SSMA, que mostra os resultados da conversão, incluindo erros, avisos, mensagens informativas, estimativas de tempo para executar a migração e etapas de correção de erro individuais a serem executadas antes de mover os objetos.

A conversão de objetos de banco de dados tira as definições de objeto dos metadados do Access, converte-as em sintaxe T-SQL (Transact-SQL) equivalente e carrega essas informações no projeto. Em seguida, você pode exibir os objetos SQL Server ou SQL Azure e suas propriedades usando SQL Server ou SQL Azure metadados Explorer.

Para converter, carregar e migrar objetos para SQL Server, siga este guia.

Dica    Depois de migrar com êxito seu banco de dados access, salve o arquivo de projeto para uso posterior, para que você possa migrar seus dados novamente para teste ou migração final.

Tabelas de link

Considere instalar a versão mais recente do SQL Server drivers OLE DB e ODBC em vez de usar os drivers de SQL Server nativos que são enviados com o Windows. Não só os drivers mais recentes são mais rápidos, mas dão suporte a novos recursos em SQL do Azure que os drivers anteriores não. Você pode instalar os drivers em cada computador em que o banco de dados convertido é usado. Para obter mais informações, consulte Microsoft OLE DB Driver 18 for SQL Server e Microsoft ODBC Driver 17 for SQL Server.

Depois de migrar as tabelas de Acesso, você pode vincular-se às tabelas em SQL Server que agora hospeda seus dados. A vinculação diretamente do Access também fornece uma maneira mais simples de exibir seus dados em vez de usar as ferramentas de gerenciamento de SQL Server mais complexas.  Você pode consultar e editar dados vinculados dependendo das permissões configuradas pelo administrador do banco de dados SQL Server.

Observação    Se você criar um DSN ODBC ao vincular ao banco de dados SQL Server durante o processo de vinculação, crie o mesmo DSN em todos os computadores que usam o novo aplicativo ou use programaticamente o cadeia de conexão armazenado no arquivo DSN.

Para obter mais informações, consulte Vincular ou importar dados de um Banco de Dados do Servidor SQL do Azure e Importar ou vincular a dados em um banco de dados SQL Server.

Dica   Não se esqueça de usar o Gerenciador de Tabelas Vinculados no Access para atualizar e revincular tabelas convenientemente. Para obter mais informações, consulte Gerenciar tabelas vinculadas.

Testar e revisar

As seções a seguir descrevem problemas comuns que você pode encontrar durante a migração e como lidar com eles.

Consultas

Somente Selecionar Consultas são convertidos; outras consultas não são, incluindo Selecionar Consultas que usam parâmetros. Algumas consultas podem não ser completamente convertidas e o SSMA relata erros de consulta durante o processo de conversão. Você pode editar manualmente objetos que não são convertidos usando a sintaxe T-SQL. Erros de sintaxe também podem exigir a conversão manual de funções e tipos de dados específicos do Access em SQL Server. Para saber mais, confira Comparar o SQL do Access com o SQL Server TSQL.

Tipos de dados

Acesso e SQL Server têm tipos de dados semelhantes, mas estejam cientes dos problemas potenciais a seguir.

Número Grande    O tipo de dados Número Grande armazena um valor não monetário e numérico e é compatível com o tipo de dados bigint do SQL. Você pode usar esse tipo de dados para calcular com eficiência números grandes, mas ele requer o uso do formato de arquivo de banco de dados .accdb do Access 16 (16.0.7812 ou posterior) e tem um desempenho melhor com a versão de 64 bits do Access. Para obter mais informações, consulte Usando o tipo de dados Número Grande e Escolha entre a versão de 64 bits ou 32 bits do Office.

Sim/Não    Por padrão, uma coluna Access Yes/No é convertida em um campo de bits SQL Server. Para evitar o bloqueio de registros, verifique se o campo bit está definido para não permitir valores NULL. NO SSMA, você pode selecionar a coluna de bits para definir a propriedade Permitir Nulls como NO. No TSQL, use as instruções CREATE TABLE ou ALTER TABLE .

Data e hora    Há várias considerações de data e hora:

  • Se o nível de compatibilidade do banco de dados for 130 (SQL Server 2016) ou superior, e uma tabela vinculada contiver uma ou mais colunas datetime ou datetime2, a tabela poderá retornar a mensagem #deleted nos resultados. Para obter mais informações, consulte Acessar tabela vinculada a SQL-Server banco de dados retorna #deleted.

  • Use o tipo de dados Data/Hora de Acesso para mapear para o tipo de dados datetime. Use o tipo de dados Data/Hora de Acesso Estendido para mapear para o tipo de dados datetime2 que tem um intervalo de data e hora maior. Para obter mais informações, consulte Usando o tipo de dados estendido data/hora.

  • Ao consultar datas no SQL Server, leve em conta a hora e a data. Por exemplo:

    • DateOrdered Entre 1/1/19 e 31/19 pode não incluir todos os pedidos.

    • DateOrdered Between 1/1/19 00:00:00 e 31/11/19 11:59:59 PM inclui todos os pedidos.

Anexo   O tipo de dados Anexo armazena um arquivo no banco de dados Access. Em SQL Server, você tem várias opções a considerar. Você pode extrair os arquivos do banco de dados access e, em seguida, considerar armazenar links para os arquivos em seu banco de dados SQL Server. Como alternativa, você pode usar FILESTREAM, FileTables ou RBS (Remote BLOB Store) para manter anexos armazenados no banco de dados SQL Server.

Hiperlink    As tabelas de acesso têm colunas de hiperlink que SQL Server não dá suporte. Por padrão, essas colunas serão convertidas em colunas nvarchar(max) em SQL Server, mas você pode personalizar o mapeamento para escolher um tipo de dados menor. Em sua solução access, você ainda pode usar o comportamento do hiperlink em formulários e relatórios se definir a propriedade Hyperlink para o controle como true.

Campo multivalorizado    O campo multivalued access é convertido em SQL Server como um campo ntext que contém o conjunto delimitado de valores. Como o SQL Server não oferece suporte a um tipo de dados de múltiplos valores que modela uma relação muitos para muitos, pode ser necessário um trabalho adicional de design e conversão.

Para obter mais informações sobre o mapeamento de tipos de dados access e SQL Server, consulte Comparar tipos de dados.

Observação    Campos multivalorizados não são convertidos.

Para obter mais informações, consulte Tipos de data e hora, tipos de cadeia de caracteres e binários e tipos numéricos.

Visual Basic

Embora o VBA não tenha suporte para SQL Server, observe os seguintes problemas possíveis:

Funções VBA em Consultas    As consultas de acesso dão suporte a funções VBA em dados em uma coluna de consulta. Mas as consultas de acesso que usam funções VBA não podem ser executadas em SQL Server, portanto, todos os dados solicitados são passados para o Microsoft Access para processamento. Na maioria dos casos, essas consultas devem ser convertidas em consultas de passagem.

Funções definidas pelo usuário em consultas    As consultas do Microsoft Access dão suporte ao uso de funções definidas em módulos VBA para processar dados passados para eles. As consultas podem ser consultas autônomas, instruções SQL em fontes de registro de formulário/relatório, fontes de dados de caixas de combinação e caixas de lista em formulários, relatórios e campos de tabela e expressões padrão ou de regra de validação. SQL Server não pode executar essas funções definidas pelo usuário. Talvez seja necessário redesenhar manualmente essas funções e convertê-las em procedimentos armazenados no SQL Server.

Otimizar o desempenho

De longe, a maneira mais importante de otimizar o desempenho com seu novo SQL Server de back-end é decidir quando usar consultas locais ou remotas. Ao migrar seus dados para SQL Server, você também está migrando de um servidor de arquivos para um modelo de banco de dados cliente-servidor de computação. Siga estas diretrizes gerais:

  • Execute consultas pequenas e somente leitura no cliente para acesso mais rápido.

  • Execute consultas longas e de leitura/gravação no servidor para aproveitar o maior poder de processamento.

  • Minimizar o tráfego de rede com filtros e agregação para transferir apenas os dados necessários.

Otimizar o desempenho no modelo de banco de dados do servidor cliente

Para obter mais informações, consulte Criar uma consulta de passagem.

A seguir estão diretrizes adicionais e recomendadas.

Colocar lógica no servidor     Seu aplicativo também pode usar exibições, funções definidas pelo usuário, procedimentos armazenados, campos calculados e gatilhos para centralizar e compartilhar lógica de aplicativo, regras e políticas de negócios, consultas complexas, validação de dados e código de integridade referencial no servidor e não no cliente. Pergunte a si mesmo, essa consulta ou tarefa pode ser executada no servidor cada vez mais rápido? Por fim, teste cada consulta para garantir o desempenho ideal.

Usar exibições em formulários e relatórios    No Access, faça o seguinte:

  • Para formulários, use uma exibição SQL para um formulário somente leitura e uma exibição indexada de SQL para um formulário de leitura/gravação como a fonte de registro.

  • Para relatórios, use uma exibição SQL como a fonte de registro. No entanto, crie uma exibição separada para cada relatório, para que você possa atualizar mais facilmente um relatório específico, sem afetar outros relatórios.

Minimizar o carregamento de dados em um formulário ou relatório    Não exiba dados até que o usuário peça. Por exemplo, mantenha a propriedade recordsource em branco, faça com que os usuários selecionem um filtro em seu formulário e, em seguida, preencha a propriedade de fonte de registro com seu filtro. Ou use a cláusula em que a cláusula DoCmd.OpenForm e DoCmd.OpenReport exibe os registros exatos necessários pelo usuário. Considere desativar a navegação de registro.

Tenha cuidado com consultas heterogêneas   Evite executar uma consulta que combine uma tabela de Acesso local e SQL Server tabela vinculada, às vezes chamada de consulta híbrida. Esse tipo de consulta ainda requer o Access para baixar todos os dados SQL Server para o computador local e, em seguida, executar a consulta, ele não executa a consulta em SQL Server.

Quando usar tabelas locais    Considere o uso de tabelas locais para dados que raramente são alterados, como a lista de estados ou províncias em um país ou região. Tabelas estáticas geralmente são usadas para filtragem e podem ter um desempenho melhor no front-end do Access.

Para obter mais informações, consulte Orientador de Otimização do Mecanismo de Banco de Dados, Use o Performance Analyzer para otimizar um banco de dados access e otimizando aplicativos do Microsoft Office Access vinculados a SQL Server.

Confira também

Guia de Migração de Banco de Dados do Azure

Blog de Migração de Dados da Microsoft

Microsoft Access to SQL Server Migration, Conversion and Upsizing

Maneiras de compartilhar um banco de dados da área de trabalho do Access

Precisa de mais ajuda?

Quer mais opções

Explore os benefícios da assinatura, procure cursos de treinamento, saiba como proteger seu dispositivo e muito mais.

As comunidades ajudam você a fazer e responder perguntas, fazer comentários e ouvir especialistas com conhecimento avançado.

Essas informações foram úteis?

Qual é o seu grau de satisfação com a qualidade do idioma?
O que afetou sua experiência?
Ao pressionar enviar, seus comentários serão usados para aprimorar os produtos e serviços da Microsoft. Seu administrador de TI poderá coletar esses dados. Política de Privacidade.

Agradecemos seus comentários!

×