Mysql数据库的表空间传输功能

从mysql5.6版本开始,引入了表空间传输的功能。可以把一张表从一个数据库移动到另一个数据库中或者另一台机器上。使用该功能必须满足如下条件:

  1. Mysql版本必须是5.6及以上
  2. 使用独立表空间方式,现在版本默认开启innodb_file_per_table
  3. 源库和目标库的page size必须一致
  4. 当表做导出操作时,该表只能进行只读操作

案例:把测试数据库test库下的表test移动到mysql数据库下面。

首先需要在mysql库下面创建表test,表结构和test库下面的表test一致。

可以在数据目录下面的mysql库目录下看到有test.ibd文件生成。如下图所示:

 

接下来需要卸载mysql库test表的表空间

mysql> alter table test discard tablespace;

 

结果就会发现刚才在mysql库目录下的test.ibd文件没有了。

 

接着需要在test库下执行表空间导出的操作

mysql>flush table test for export;

 

导出完成后,会发先test库目录下多了一个test.cfg文件,

 

将目录下的test.cfg文件和test.ibd文件复制到mysql库目录下面。并且修改mysql权限。

cp test.{cfg,ibd} /var/lib/mysql/mysql/

cd /var/lib/mysql/

chown mysql:mysql -R mysql/

 

因为目前是只读状态,需要解锁:

mysql> unlock tables;

 

最后在mysql库下面执行表空间导入操作:

mysql> alter table test import tablespace;

最后发现,mysql库下面的test表里面已经存在数据了。 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

#慧#

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值