首页 > 数据库 > MySQL > 正文

mysql 数据库备份的多种实现方式总结

2024-07-24 12:54:30
字体:
来源:转载
供稿:网友

本文实例讲述了mysql 数据库备份的多种实现方式。,具体如下:

一、使用mysqldump进行备份

1、完整备份所有数据库

mysqldump -u root -p --all-databases > E:/all.sql

在mysql8之前,存储过程和事件存储在mysql.proc和mysql.event表中。

从mysql8开始,相应对象的定义存储在数据字典中,这些表不会被备份。

要将存储过程和事件也包含,请使用如下语句:

mysqldump -u root -p --all-databases --routines --events > E:/all.sql

2、时间点恢复

要获得时间点恢复,应该指定--single-transaction 和 --master-data

--single-transaction 在备份之前,会将事务隔离级别设为REPEATABLE READ模式,并执行 START TRANSACTION 来提供一致的备份。

--master-data 将服务器的二进制日志的位置输出到 sql 文件。

mysqldump -u root -p --all-databases --routines --events --single-transaction --master-data > E:/all.sql

--master-data = 2表示在导出过程中,记录当前库的binlog和pos点,并在导出文件中注释这一行。

--master-data = 1表示在导出过程中,记录当前库的binlog和pos点,并在导出文件中不注释这一行。

3、在从库导出时,记录主库的二进制日志位置

mysqldump -u root -p --all-databases --routines --events --single-transaction --dump-slave > E:/all.sql

--dump-slave = 2表示在导出过程中,记录主库的binlog和pos点,并在导出文件中注释这一行。

--dump-slave = 1表示在导出过程中,记录主库的binlog和pos点,并在导出文件中不注释这一行。

4、指定数据库和表导出

mysqldump -u root -p --databases 数据库 > E:/bak.sqlmysqldump -u root -p --databases 数据库 --tables 数据表 > E:/bak.sql

5、忽略表

mysqldump -u root -p --databases 数据库 --ignore-table=数据库.数据表 > E:/bak.sql

6、指定行

mysqldump -u root -p --databases 数据库 --tables 数据表 --where="条件" > E:/bak.sql

或者用limit限制结果集

mysqldump -u root -p --databases 数据库 --tables 数据表 --where="条件 LIMIT 条数" > E:/bak.sql

7、导出远程服务器

mysqldump -u root -p -h 主机IP --all-databases --routines --events --triggers > E:/all.sql

8、用于与其他服务器合并数据的备份

mysqldump -u root -p --databases 数据库 --skip-add-drop-table --replace > E:/bak.sql

--skip-add-drop-table: 不会将drop table语句写入导出文件中。

--replace:将使用replace into语句而不是insert语句导出。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表