- 查看当前表空间情况
在mysql命令行下使用命令:show variables like '%per_table'; 还可以进mysql的数据存储文件夹,查看表的文件结构来确定是什么类型的表空间。 - 将共享表空间转化为独立表空间
- 方法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中。