大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说MySQL学习笔记(27):备份与恢复,希望您对编程的造诣更进一步.
本文更新于2020-05-03,使用MySQL 5.7,操作系统为Deepin 15.4。
MySQL的备份分为逻辑备份和物理备份,物理备份分为冷备份和热备份。恢复分为完全恢复和不完全恢复,不完全恢复又分为基于时间点的恢复和基于位置的恢复。
逻辑备份和恢复
使用mysqldump进行逻辑备份,如mysqldump dbname > filename
。
为了保证数据备份的一致性,MyISAM存储引擎需加上-l参数,如InnoDB等事务存储引擎应加上–single-transaction。
恢复包括两个步骤:
- 使用备份数据恢复,如
mysql dbname < backupfilename
。 - 将备份后至恢复前的日志重做(不要把上一步执行时的二进制日志也重做了),如
mysqlbinlog logfilename | mysql dbname
。可进行不完全恢复,但要注意是否包含完整的事务,如mysqlbinlog --start-date=start logfilename | mysql dbname
或mysqlbinlog --start-position=position logfilename | mysql dbname
。
物理备份和恢复
冷备份和恢复
冷备份就是停掉数据库服务,拷贝数据文件。
热备份和恢复
对MyISAM存储引擎,热备份可使用mysqlhotcopy
,本质就是将要备份的表加读锁,然后拷贝数据文件。
对InnoDB存储引擎,可安装使用ibbackup、Xtrabackup(包括xtrabackup和innobackupex两个主要工具)等工具。
表数据导入导出
表数据导出有两种方法:
- 使用
SELECT ... INTO OUTFILE filename [options]
。 - 使用
mysqldump -T
。
表数据导入有两种方法:
LOAD DATA [LOCAL] INFILE filename INTO TABLE tablename [options]
。mysqlimport dbname filename
。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6993.html