MySQL: Duplicando uma tabela com apenas 1 comando SQL

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

[ Hits: 92.022 ]

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

MongoDB Community Edition 4.2 no Debian 10 Buster

Instalando Docker no Debian 10 Buster

Verificar bateria do mouse bluetooth via linha de comando

Treinamento oficial SuSE/Novell

Como restaurar as cores do terminal

Leitura recomendada

Client MySQL com auto-completion e syntax highlighting

Reset de senha no MySQL

Recuperar senha de root do MySQL 8 no Fedora

Migrando um banco MYSQL para outra máquina

MySQL Error: #1558 - Column count of mysql.proc is wrong. Expected 20, found 16. ... Please use mysql_upgrade to fix this error

  

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