MySQL How To Duplicate A Table – Fast Tips

Valerio Barbera

Recently I had to deal with some limitations of my database provider that doesn’t support table renaming. So I had to duplicate a table manually.

The database of my SaaS platform is hosted on Planetscale. The company provides a MySQL-compatible serverless database. Thanks to its serverless nature you can get the power of horizontal sharding, non-blocking schema changes, and many more powerful database features without the pain of implementing them. And a great developer experience.

From another perspective you have to deal with some constraint regarding schema changes. These limitations are needed to guarantee consistency in a sharded environment.

They made a lot of progress since I became a customer (almost two years ago), like the support for Foreign Key constraint: https://planetscale.com/docs/concepts/foreign-key-constraints

Rename a table

Inspector is a Laravel application. Using the Laravel migrations I could use the rename function to simply change the name of a table:

Schema::rename('from', 'to');

Planetscale doesn’t support table renaming natively. So I had to find a workaround to accomplish the task.

To be honest renaming a table is a quite rare operation. For me it was because of an overlap of names between “Projects” and “Applications” entities. I had to rename Projects -> Applications.

How to duplicate a table in MySQL

There are two ways to duplicate a table in MySQL.

Duplicate the table structure

You can duplicate only the table structure (columns, keys, indexes, etc) without data, using “CREATE TABLE … LIKE”:

CREATE TABLE applications LIKE projects;

The result is the creation of the applications table with the exact same structure of the original projects table, but WITH NO data.

To import data too you can run a second statement as “INSERT INTO … SELECT”:

INSERT INTO applications SELECT * FROM projects;

Take care running this statement on big tables because it can take a lot of time and server resources.

Duplicate only column definition

The second option is to duplicate only column definitions and import data in one statement using “CREATE TABLE … AS SELECT”:

CREATE TABLE applications AS SELECT * FROM projects;

The new applications table inherits only the basic column definitions from the projects table. It does not duplicate Foreign Key constraints, indexes, and auto_increment definitions.

This option could be usefult when you have the names of indexes and keys related to the table name. Changing the name of the table you have to replace the names of the constraints. You’d better not import them at all and do it all over again.

Resources

Database is always an hot topic for developers at any stage. You can find other technical resources on the blog. Here are the most popular articles on the topic:

New To Inspector? Monitor your application for free

Inspector is a Code Execution Monitoring tool specifically designed for software developers. You don’t need to install anything in the infrastructure, just install the composer package and you are ready to go.

Unlike other complex, all-in-one platforms, Inspector is super easy, and PHP friendly. You can try our Laravel or Symfony package.

If you are looking for effective automation, deep insights, and the ability to forward alerts and notifications into your messaging environment try Inspector for free. Register your account.

Or learn more on the website: https://inspector.dev

Related Posts

How to Stop a Streamed AI Response Mid-Flight in Neuron AI v3

One thing I didn’t anticipate when building Neuron AI was how many edge cases would surface not from the AI integration itself, but from the UI layer sitting on top of it. Developers don’t just want agents that work. They want agents that feel right to use. And the moment you start building chat interfaces

Conversational Data Collection: Introducing AIForm

One of the more interesting things about building an open-source framework is that the community often knows what to build next before you do. When I started Neuron AI, I had a fairly clear picture in my head of the core primitives: agents, tools, workflows, structured output. What I didn’t fully anticipate was how quickly

Neuron AI Now Supports ZAI — The GLM Series Is Worth Your Attention

There’s a pattern I’ve noticed over the past year while working on Neuron AI: the decisions that matter most are rarely about chasing trends. They’re about quietly recognizing something that works, testing it seriously, and integrating it so that other developers can benefit without having to do that work themselves. That’s the honest story behind