Duplicate Table in MySQL
You can copy or duplicate MySQL table to another table. Duplicating MySQL table is useful when you would like to run some experiments on the table, but want to have a backup of the table. Or in some scenarios, you would like to create a table with exact columns and indexes of an already existing table.
There are two levels to duplicate a MySQL table based on the totality of duplicating table.
- Duplicate only structure and data of the table
- Duplicate structure and data of the table along with indexes and triggers.
Duplicate structure and data of MySQL Table
Columns and their properties such as datatypes, default values, charactersets, etc., is called structure of the tables. And rows in that table is data.
To duplicate structure and data of MySQL Table, CREATE a new TABLE with the data selected from the previous table. Following is the syntax:
CREATE TABLE new_table AS SELECT * FROM old_table;
Example – Duplicate Table
Following is the students
table’s structure.
data:image/s3,"s3://crabby-images/3f604/3f604c1ff3b78b075cc34d78358d49b22926fd9b" alt="Describe MySQL Table structure"
And students
table has the following data.
data:image/s3,"s3://crabby-images/9f526/9f526d7c8efcd8ea3afa94475bb29ca4b5c92aed" alt="show mysql table data"
Now we shall copy the structure and data of students
into a new table pupils
.
data:image/s3,"s3://crabby-images/7bb66/7bb660409a9fba67ccfcb333416ef713ff3ee8a3" alt="MySQL Duplicate Table with Structure and Data"
Let us see if both duplicate and original tables exist.
data:image/s3,"s3://crabby-images/91ead/91ead1e75acf05e8c4ecf3adaeb34e74c3543071" alt="MySQL SHOW TABLES"
Yeah. There they are. And it is time to check if the structure and data of pupils
table is exactly same as that of students
.
data:image/s3,"s3://crabby-images/16493/164934cbaae341d817a0059e7a2b21d9acaa86be" alt="MySQL Duplicated Table Structure"
data:image/s3,"s3://crabby-images/4ad97/4ad9754243f3d1fc69395a88a20de969262c8bca" alt="MySQL Duplicated Table Data"
Thats it for the first level of duplication! We have successfully duplicated a table’s structure and rows in it.
Duplicate structure and data of the table along with indexes and triggers
To duplicate MySQL Table’s indexes and triggers also along with structure and data, you have to run two SQL Queries in mysql command line interface.
CREATE TABLE new_table LIKE old_table;
INSERT new_table SELECT * FROM old_table;
- The first query creates a table with the same structure, index and triggers as of the old table.
- The second query copies the data from old table to new table.
To check the effect on index, we shall add a new column to mysql table students
and try duplicating the table.
students
table structure
data:image/s3,"s3://crabby-images/878a1/878a19946dc97893762719465fd52bb1a39ae399" alt="MySQL after adding a new column to the table"
students
table index
data:image/s3,"s3://crabby-images/827c1/827c106c21928b903a67e59d7bed9ed211d038b9" alt="MySQL show index of table"
Now we shall try to duplicate all of this table (data, structure, index and triggers) into a new table called pupils
.
Run the following two queries.
CREATE TABLE pupils LIKE students;
INSERT pupils SELECT * FROM students;
data:image/s3,"s3://crabby-images/87c8a/87c8afe06d924a99d263d851e77add588e379a85" alt="MySQL Copy table with index"
Let us see what happened to the index of newly created table pupils
.
data:image/s3,"s3://crabby-images/1754c/1754c162ef16d71a01c64b5d423b1fd0357619b2" alt="MySQL Index of Duplicated Table"
Conclusion
In this MySQL Tutorial, we learned to duplicate a table (structure and data, optionally index and triggers).