Backup & Restore MySQL Databases with mysqldump
In this article, we'll discover how to back up a MySQL database using the mysqldump
utility in the command line. Then we'll quickly walk through restoring that database from the output file.
There are many options for backing up a database using this tool. We won't cover all of them in this article, but there are some very useful options that are good to know when creating quick backups.
Backing Up Your Entire MySQL Database
The most common backup approach I take is backing up an entire MySQL database into a single file. This approach backs up everything, including the database, table structure, and table data:
mysqldump -u [username] --password=[password] [database-name] > [filename].sql
The command is simple. Here, we define the database username and password using the -u
and --password
options so we can connect to our database without a credentials prompt. Then we define the name of our database and an output filename.
Backing Up Multiple Databases at Once
If you have multiple databases you'd like to back up into a single file, you can do so by adding the --databases
option and a space-delimited list of database names:
mysqldump -u [username] --password=[password] --databases [database-name-1] [database-name-2] > [filename].sql
If you want to back up all of your databases without naming them individually, you can do so with the --all-databases
option:
mysqldump -u [username] --password=[password] --all-databases > [filename].sql
Backing Up A Single Table Only
The command for backing up a single table and its data is almost identical to backing up an entire database. The only difference is you need to add the table name after the database name to the command:
mysqldump -u [username] --password=[password] [database-name] [table-name] > [filename].sql
Backing Up the Database Structure Only
If you want to back up your database and table structure only, omitting all table data from the database, this command will do the trick for you when adding the --no-data
option:
mysqldump -u [username] --password=[password] --no-data [database-name] > [filename].sql
Date and Time Backups
There may be a scenario where you want to back up your MySQL databases on a schedule instead of doing it manually each time. This can be accomplished by creating scheduled tasks with Crontab in Linux.
If you need to create daily backups and need a file naming structure that differentiates each backup file, you can use this command:
mysqldump -u [username] --password=[password] [database-name] > mydb-$(date +\%Y\-\%m\-\%d).sql
This creates a database backup to a file with the name containing the current date, including year %Y
, month %m
, and day %d
. In this case, the filename would be mydb-2022-01-08.sql.
If you need to create multiple backups at different times of each day, you can also include the current hour, minute, and second in your filename:
mysqldump -u [username] --password=[password] [database-name] > mydb-$(date +\%Y\-\%m\-\%d_\%H-\%M-\%S).sql
Restoring Your MySQL Database
When restoring your MySQL database, all you need to do is open the generated .sql
backup file, and copy and paste the contents into your command prompt or MySQL Workbench if you're using that.
Before doing so, make sure you have a MySQL connection open and that you're using the correct database:
use [database-name];
Conclusion
That's all there is to it! These are the most common options I use when backing up databases and they've proven to be helpful time and time again.
If there are any other helpful backup options you know of, let us know in the comments below!
Written by: Josh Rowe
Created: January 08, 2022