备份InnoDB的表时,可以使用可移动表空间执行部分备份,可以备份单独的表,也可以备份具有相同业务功能的多个表。
当用户将希望将源服务器上的一个表复制到另外一台服务器上时,可以采用可移动表空间来实现,具体如下:
1、我们可以在源服务器上执行“FLUSH TABLE … FOR EXPORT”将表静止并创建“.cfg”元数据文件。
SQL > FLUSH TABLES actor FOR EXPORT;
“.cfg”文件将会创建在数据路径下:
C:ProgramDataMySQLMySQL Server 8.3Datasakila 的目录
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;
5、在目标服务器上导入复制过来的表空间
SQL >ALTER TABLE actor IMPORT TABLESPACE;
如果我们进行备份的是带有分区的InnoDB表,则需要对每个分区导出元数据文件,并将每个分区的“
.ibd”文件和“.cfg”文件执行导出、导入的操作。