mysql数据库引擎innodb从共享表空间切换到独立表空间*

原创
2016/11/11 15:08
阅读数 449
  1. 查看当前表空间情况
    在mysql命令行下使用命令:show variables like '%per_table'; 还可以进mysql的数据存储文件夹,查看表的文件结构来确定是什么类型的表空间。
  2. 将共享表空间转化为独立表空间
  • 方法1是先逻辑备份(就是使用mysqldump先导出数据,等修改之后再导入数据),然后修改配置文件my.cnf中的参数innodb_file_per_table参数为1,重启服务后将逻辑备份导入即可。
  • 方法2的这种方式原来库中的表中的数据会继续存放于ibdata1中,新的数据和新建的表才会使用独立表空间。
    1).查看那些表使用innodb数据库引擎,TABLE_SCHEMA='test'表示查询test数据库中的表,并记录下来。
SELECT `TABLES`.TABLE_SCHEMA,`TABLES`.TABLE_NAME,`TABLES`.`ENGINE` FROM information_schema.`TABLES` WHERE `ENGINE`='INNODB' AND TABLE_SCHEMA='test';

2).修改配置文件my.cnf中的参数,修改innodb_file_per_table为1,重启服务。
3).将需要修改的所有innodb表都执行一遍:alter table student engine=innodb; 执行了这步之后,旧表才会生成.ibd文件(不执行,旧表就不会生成.ibd文件,新数据还是插入到.ibd文件),新插入的数据就会放到.ibd中。

参考:innodb共享表空间转化为独立表空间

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
0 评论
0 收藏
0
分享
返回顶部
顶部