MySQL: Duplicando uma tabela com apenas 1 comando SQL

Publicado por Fábio Berbert de Paula em 06/08/2009

[ Hits: 90.959 ]

Blog: https://fabio.automatizando.dev

 


MySQL: Duplicando uma tabela com apenas 1 comando SQL



Duplicar uma tabela no MySQL, mantendo sua estrutura e importando os registros da tabela original, é mais fácil do que eu imaginava.

Hoje precisei fazer isso e uma rápida googlada me levou até: SQL COPY MySQL TABLE with structure and records.

Sem mais delongas, no console de seu MySQL digite a seguinte query:

CREATE TABLE novaTabela SELECT * FROM tabelaPai;

Simples assim!

Outras dicas deste autor

Substituindo o sleep por um belo cronômetro regressivo

Vim - incrementando números em substituição

Como usar o xmodmap para mapear teclas

Convertendo vídeo OGV (vídeo/OGG) para AVI/MPEG/MP4

Vim - Convertendo texto selecionado para uppercase ou lowercase

Leitura recomendada

MySQL - Recuperar dados em ordem aleatória (randômica)

Erro 2002 (HY000) ao conectar ao MySQL

Configurando acesso remoto em servidores MySQL

MySQL Control Center - Gerenciando seu MySQL

Solucionando o erro de "Bind on TCP/IP port" no MySQL

  

Comentários
[1] Comentário enviado por julianometal em 22/03/2010 - 12:11h

Boa dica para quando precisamos criar outra tabela a partir de uma outra copiando sua estrutura e seus registros.
Vou acrescentar aqui, se este comando fosse no Postgres só teria uma palavrinha a mais:

CREATE TABLE novaTabela AS SELECT * FROM tabelaPai;

[2] Comentário enviado por gianclaudio em 27/04/2010 - 19:10h

Olá a todos.

Na verdade, aqui o resultado não foi exatamente o esperado.
Ele criou a tabela nova e copiou todos os registros porém não definiu a chave primária, índices nem autoincremento.
Pra resolver, quase tão fácil quanto o proposto acima:

CREATE TABLE nova_tabela LIKE tabela_antiga;
INSERT INTO nova_tabela SELECT * FROM tabela_antiga;

Deste modo, a tabela é criada fielmente com índices, autoincremento etc e todos os registros copiados.
Lembrando que o SELECT pode ter filtros normalmente, podendo selecionar os registros que irão para a nova tabela.

Abração

[3] Comentário enviado por pethros em 31/12/2012 - 10:03h

Muito Obrigado!

[4] Comentário enviado por miqueloti em 19/08/2014 - 17:16h

Valeu!



Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts