How to copy a mysql database using mysqldump How to create a copy of a mysql database using mysqldump, create database and source commands and make your tests on that copy of your original(production)database (of course, in case you have one server to test it on)..
How to create a copy of a mysql database using mysqldump, create database and source commands and make your tests on that copy of your original(production)database (of course, in case you have one server to test it on).
1. Back-up the original database that you want to "clone"
In case you you have a mysql password for user root you need to use mysql(dump) -u root -p dbname and you will be asked for root password by mysql program. If you don't wish to be asked you can youse mysql(dump) -u root -ppassword (yes, one word) dbname to access or backup the database (mysqldump) and you can redirect the output (in case of backup) to a file (preferably .sql file).
$ mysqldump -u root -p dbname >~/db_name.sql
I used home directory absolute path because we will use it in step 3 - Populating the copy of the mysql database.
2. Creating the copy of the mysql database
Now that we have the file that is the database backup (~/db_name.sql) we can go ahead and connect to mysql database using mysql command:
$ mysql -u root -pmypassword Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 812 Server version: 5.1.20-beta-log FreeBSD port: mysql-server-5.1.20
Type 'help;' or 'h' for help. Type 'c' to clear the buffer.
mysql> create database dbname_copy mysql> use dbname_copy
note that mysql> is mysql prompt. From here you can give all commands thatyou will give to this mysql db. 1st command creates a new database and 2nd command tells the client to use that database.
3. Populating the copy of the mysql database
(previous step use dbname_copy)
mysql> source ~/db_name.sql
This command populates the copy of your database with the contents of your original database backed up in ~/db_name.sql file.
Now you can check both mysql databases dbname and dbname_copy and see that they are identical and you can perform any tests on dbname_copy database.
This whole operation was similar to a mysql database backup or mysql database moveprocedure which I will cover in a future tutorial.
Note: dbname and dbname_copy must be changed to your needs.
Hello, Guest ! You can Login or Register to www.ivorde.ro!
Post comment:
6 comment(s) to How to copy a mysql database using mysqldump:
1. Re: How to copy a mysql database using mysqldump
-h command indicates the host by Alejandro Arauz
at October 14th, 2011 - 19:04
hey Jennifer, the -h command indicates the host, by default the command uses localhost. The mysqldump command has many options and can be confusing sometimes. If you want a more friendly way to backup your database maybe you can use a tool. I use the free version of MySQLBackupFTP (http://mysqlbackupftp.com). The tool is easy to use due to its simple GUI and it has useful features like file compression and email notification.
2. Re: How to copy a mysql database using mysqldump
Thank You by Nick
at July 15th, 2011 - 14:41
Concise and easy to understand. Thanks
3. Re: How to copy a mysql database using mysqldump
-h Command does waht? by Jennifer
at April 29th, 2011 - 02:21
What does the -h command do? I see some places use it and some do not. For example check this tutorial: http://www.fortasse.com/tutorials/mysqldump-mysql-database-backup/
They use -h. What does it mean?
4. Re: How to copy a mysql database using mysqldump
great job by zarzu
at January 28th, 2011 - 15:33
THANKS...3 years later and its still helpful :D
5. Re: How to copy a mysql database using mysqldump
Worked great by Leumas
at November 06th, 2008 - 06:30
thanks!
6. Re: How to copy a mysql database using mysqldump
Designed and developed by Andrei Manescu. Optimized for Mozilla Firefox.
Copyright 2007 Andrei Manescu
All trademarks and copyrights on this page are owned by their respective owners. Comments are owned by those who posted them.