MySQL数据库管理--迁移表操作步骤

下面一起来了解下MySQL数据库管理--迁移表操作步骤,相信大家看完肯定会受益匪浅,文字在精不在多,希望MysqL数据库管理--迁移表操作步骤这篇短内容是你想要的。                                                         

通过复制InnoDB表的ibd文件,实现将InnoDB表从源库迁移到目标库,类似Oracle TTS。

传输表空间的限制:
1,MysqL 版本 5.6.6 及其以上,源和目标版本建议都是GA版并且大版本一样
2,表引擎为innodb并且开启独立表空间(innodb_file_per_table=1)
3,处于导出状态的表只允许读也就是”read_only“状态
4,disCARD TABLESPACE不支持分区表[5.6.17才支持] 并且当表上具有外键关系的时候需要将foreign_key_check设置为0
5,源和目标实例的page size必须大小一致
6,ALTER TABLE ... IMPORT TABLESPACE不强制进行外键约束检查,所以需要将主表和子表都导出,然后在目标实例导入

源库
[root@wallet01 ~]# su - MysqL
[MysqL@wallet01 ~]$ MysqLdump -uroot -pabcd.1234 -d tpcc customer >customer.sql
[MysqL@wallet01 ~]$ scp customer.sql 192.168.1.202:/home/MysqL

[MysqL@wallet01 ~]$ MysqL -uroot -pabcd.1234
MysqL> use tpcc100
Database changed

MysqL> select count(*) from customer;
+----------+
| count(*) |
+----------+
|  1500000 |
+----------+
1 row in set (0.33 sec)

目标库
[root@wallet02 ~]# su - MysqL
[MysqL@wallet02 ~]$ MysqL -uroot -pabcd.1234
MysqL> create database tpcc;
Query OK, 1 row affected (0.05 sec)

MysqL> use tpcc
Database changed

MysqL> source customer.sql
Query OK, 0 rows affected (0.01 sec)

MysqL>  alter table customer discard tablespace;
Query OK, 0 rows affected (0.03 sec)

源库
MysqL> flush table customer for export;
Query OK, 0 rows affected (0.00 sec)

[MysqL@wallet01 ~]$ cd /usr/local/MysqL/data/tpcc
[MysqL@wallet01 tpcc]$ scp customer.cfg 192.168.1.202:/usr/local/MysqL/data/tpcc
[MysqL@wallet01 tpcc]$ scp customer.ibd 192.168.1.202:/usr/local/MysqL/data/tpcc

MysqL>  unlock tables;
Query OK, 0 rows affected (0.03 sec)

目标库
MysqL> alter table customer import tablespace; 
Query OK, 0 rows affected (11.52 sec)

MysqL> select count(*) from customer;
+----------+
| count(*) |
+----------+
|  1500000 |
+----------+

1 row in set (0.37 sec)

看完MysqL数据库管理--迁移表操作步骤这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的行业资讯栏目。

相关文章

MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导...
在MySQL中,InnoDB引擎通过Next-Key Locking技术来解决幻读问...
在数据库事务管理中,Undo Log 和 Redo Log 是两种关键日志,...
case when概述 sql语句中的case语句与高级语言中的switch语句...
其实很简单,只是为了忘记,做个记录,用的时候方便。 不管是...
1.进入服务,找到mysql服务,在属性里找到mysql的安装路径 2...