MySQL does not have a clone command. To Clone a table is to create a replica, and for creating a coy of the table, we can use:
- Create a table using the select statement
- Create a table and then insert it with the select clause
Pre-requisites
Command-line client:
- Log in to the command-line client with user credentials. The User should have select, Create and Insert table privileges.
- Select a database to work with using the USE statement.
MySQL Workbench:
- Open a new connection with user credentials. The User should have select, create, and insert table privileges.
- Select a database with the
USE
statement.
Create table...Select in MySQL using the command line client
- To make a copy of a table as-is, we do:
CREATE TABLE <new_table-name>
SELECT * from <orig_table_name>;
example:
CREATE TABLE employees2
SELECT * FROM employees;
data:image/s3,"s3://crabby-images/132d0/132d03c87128d0ee9edff38a3156623ab10dd10a" alt=""
- The command above would create a new table and insert all the data as well. It does not copy triggers, indexes, etc., from the earlier table to the next one.
data:image/s3,"s3://crabby-images/9198f/9198fbb348daa07e9ae8e3842f131599c49a65ee" alt=""
CREATE Table ... Select specific columns in MySQL using command-line client
- Instead of creating a new table with the same columns, we can choose the columns we require and even combine columns as in the below example.
create table employee_subset
select emp_id, CONCAT(first_name," , ",last_name)
from employees;
data:image/s3,"s3://crabby-images/9c7ee/9c7ee0e6ab2c079b41ec0bdb5fa38a27f477dd1f" alt=""
- All the records based on the columns we have selected are inserted into the new table.
data:image/s3,"s3://crabby-images/b6bd7/b6bd7982a11ba9ab211cddd7926e75e40b445d33" alt=""
Copy a table from another database in MySQL using MySQL Workbench
- The syntax to copy a table from one database to the other is as follows:
CREATE table <current_schema.table_name>
select * from <other_Schema.table_name>;
Example: To copy the city table from the Sakila database to the current database.
CREATE TABLE TESTDB.CITY SELECT * FROM sakila.CITY;
data:image/s3,"s3://crabby-images/667f4/667f401c0d4457a9f08806b3a8f4a1ea5266bcb2" alt=""
Create a table and insert records in MySQL using MySQL Workbench
- To create a table with the same structure as some table, we use:
Create Table <table_name> Like <other_table>
e.g., To create a table like the country table of the Sakila database in our current database, we do
CREATE TABLE TEST_TABLE LIKE sakila.COUNTRY;
data:image/s3,"s3://crabby-images/b784d/b784ddd17a11dc3d6d24192eadc28c2905558343" alt=""
- The above command copies the table structure but not the data.
data:image/s3,"s3://crabby-images/3ef90/3ef90174fa2915eb7ca6f6967ce0a710e4bdbf7e" alt=""
- After creating the table, we can either Insert data from the other table or entirely new values.
- To insert data from the other table, we do
INSERT INTO TEST_TABLE
select * from sakila.country;
Select * from TEST_TABLE;
data:image/s3,"s3://crabby-images/e0e02/e0e02de0468ef8b44ee077da38473e233d0de8ee" alt=""