浅谈mysql数据库备份

在平时的开发工作中是非常重视备份数据库的。一般企业都会隔一小段时间就全盘备份一次,甚至每天都增量备份,一周全备一次。因为企业数据实在是太重要了。大家工作再细致,网络安全再完备,也难免会出现硬件错误或者黑客攻击,甚至人为出错的情况都会有。如果没有做好备份,一旦数据损毁,那就不是简单地数据重新录入的问题了,甚至会严重影响企业正常业务的开展。所以,平时开发中还是要做好数据库备份的,下面介绍一种数据库备份的方法 —— mysqldump备份数据库

1、备份命令
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 > 文件名.sql

mysqldump -h 127.0.0.1 -p 3306 -uroot -ppassword --database csdm > /data/csdm.sql

2、备份压缩
导出的数据有可能比较大,不好备份到远程,这时候就需要进行压缩
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 | gzip > 文件名.sql.gz

mysqldump -h 127.0.0.1 -p 3306 -uroot -ppassword --database csdm | gzip > /data/csdm.sql.gz

3、备份同个库多个表
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --database 数据库名 表1 表2 … > 文件名.sql

mysqldump -h 127.0.0.1 -p3306 -uroot -ppassword csdm t1 t2 > /data/csdm_t1_t2.sql

4、同时备份多个库
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --databases 数据库名1 数据库名2 数据库名3 > 文件名.sql

mysqldump -h 127.0.0.1 -p3306 -uroot -ppassword --databases csdm bbs blog > /data/mutil_db.sql

5、备份实例上所有的数据库
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --all-databases > 文件名.sql

mysqldump -h 127.0.0.1 -p3306 -uroot -ppassword --all-databases > /data/all_db.sql

6、备份数据出带删除数据库或者表的sql备份
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --add-drop-table --add-drop-database 数据库名 > 文件名.sql

mysqldump -h 127.0.0.1 -p3306 -uroot -ppassword --add-drop-table --add-drop-database csdm > /data/db.sql

7、备份数据库结构,不备份数据
格式:mysqldump -h主机名 -P端口 -u用户名 -p密码 --no-data 数据库名1 数据库名2 数据库名3 > 文件名.sql

mysqldump -h 127.0.0.1 -p3306 -uroot -ppassword --no-data –databases db1 db2 csdm > /data/structure.sql

注意:如果要实现定时备份数据库的话,可以在linux配合crontab定时任务来实现,crontab -e 编辑加入保存定时任务,保存退出后 crontab -l 查看定时任务。如下是在 crontab -e 中加入的定时任务:

00 01 * * * /usr/bin/mysqldump -h 127.0.0.1 -uroot -p1234 stools  > /home/www/basebase/stools.sql

小伙伴,如果觉得对你有帮助,帮我点下赞呗。

你可能感兴趣的:(MySql)