备份InnoDB的表时,可以使用可移动表空间执行部分备份,可以备份单独的表,也可以备份具有相同业务功能的多个表。
当用户将希望将源服务器上的一个表复制到另外一台服务器上时,可以采用可移动表空间来实现,具体如下:
在源服务器上执行“FLUSH TABLE ... FOR EXPORT”将表静止并创建“.cfg”元数据文件。
SQL > FLUSH TABLES actor FOR EXPORT;
“.cfg”文件将会创建在数据路径下:
C:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录
2024/03/06 15:24 <DIR> .
2024/03/04 13:59 <DIR> ..
2024/03/06 15:24 1,003 actor.cfg
2024/01/17 10:51 131,072 actor.ibd
将“
.ibd”文件和“.cfg”文件复制到目标服务器。
在源服务器上执行“UNLOCK TABLES”释放表上的锁。
在目标服务器上创建一个相同结构的表,之后销毁表空间
SQL >ALTER TABLE actor DISCARD TABLESPACE;
在目标服务器上导入复制过来的表空间
SQL >ALTER TABLE actor IMPORT TABLESPACE;
注意,如果进行备份的表是带有分区的InnoDB表,则需要对每个分区导出元数据文件,并需要将每个分区的“
.ibd”文件和“.cfg”文件执行导出、导入的操作。