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

  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共享表空间转化为独立表空间

转载于:https://my.oschina.net/cjun/blog/786321

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值