备份InnoDB的表时,可以使用可移动表空间执行部分备份,可以备份单独的表,也可以备份具有相同业务功能的多个表。
当用户将希望将源服务器上的一个表复制到另外一台服务器上时,可以采用可移动表空间来实现,具体如下:
1、我们可以在源服务器上执行“FLUSH TABLE … FOR EXPORT”将表静止并创建“.cfg”元数据文件。
SQL > FLUSH TABLES actor FOR EXPORT;SQL > FLUSH TABLES actor FOR EXPORT;SQL > FLUSH TABLES actor FOR EXPORT;
“.cfg”文件将会创建在数据路径下:
C:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录2024/03/25 9:24 <DIR> .2024/03/25 9:59 <DIR> ..2024/03/25 9:24 1,003 actor.cfg2024/03/25 9/:51 131,072 actor.ibdC:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录 2024/03/25 9:24 <DIR> . 2024/03/25 9:59 <DIR> .. 2024/03/25 9:24 1,003 actor.cfg 2024/03/25 9/:51 131,072 actor.ibdC:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录 2024/03/25 9:24 <DIR> . 2024/03/25 9:59 <DIR> .. 2024/03/25 9:24 1,003 actor.cfg 2024/03/25 9/:51 131,072 actor.ibd
2、将“
.ibd”文件和“.cfg”文件复制到目标服务器。
3、在源服务器上执行“UNLOCK TABLES”释放表上的锁。
4、在目标服务器上创建一个相同结构的表,之后销毁表空间
SQL >ALTER TABLE actor DISCARD TABLESPACE;SQL >ALTER TABLE actor DISCARD TABLESPACE;SQL >ALTER TABLE actor DISCARD TABLESPACE;
5、在目标服务器上导入复制过来的表空间
SQL >ALTER TABLE actor IMPORT TABLESPACE;SQL >ALTER TABLE actor IMPORT TABLESPACE;SQL >ALTER TABLE actor IMPORT TABLESPACE;
如果我们进行备份的是带有分区的InnoDB表,则需要对每个分区导出元数据文件,并将每个分区的“
.ibd”文件和“.cfg”文件执行导出、导入的操作。
© 版权声明
本站文章由不念博客原创,未经允许严禁转载!
THE END