一个 InnoDB 表包含两部分,即:表结构定义和数据。在 MySQL 8.0 版本以前,表结构是存在以.frm 为后缀的文件里。而 MySQL 8.0 版本,则已经允许把表结构定义放在系统数据表中了。
表数据既可以存在共享表空间里,也可以是单独的文件。 这个行为是由参数 innodb_file_per_table 控制的:
这个参数设置为 OFF 表示的是,表的数据放在系统共享表空间,也就是跟数据字典放在一起;
这个参数设置为 ON 表示的是,每个 InnoDB 表数据存储在一个以 .ibd 为后缀的文件中。
从 MySQL 5.6.6 版本开始,它的默认值就是 ON 了。
将这个值设置为 ON,一个表单独存储为一个文件更容易管理,而且在不需要这个表的时候,通过 drop table 命令,系统就会直接删除这个文件。而如果是放在共享表空间中,即使表删掉了,空间也是不会回收的。
数据页的复用跟记录的复用是不同的。
不止是删除数据会造成空洞,插入数据也会。
一个表 t 文件大小为 1TB; 对这个表执行 alter table t engine=InnoDB; 发现执行完成后,空间不仅没变小,还稍微大了一点儿,比如变成了 1.01TB。
磁盘压力很小,但是数据库出现间歇性的性能下跌。