下面介绍每种数据表文件:
isam数据表是最原始的数据表,有三个文件,分别是:
.frm,存放数据表的结构定义;
.isd,数据文件,存放数据表中的各个数据行的内空;
.ism,索引文件,存放数据表的所有索引信息。
myisam数据表是isam数据表的继承者,也有三个文件,分别是:
.frm,结构定义文件;
.myd,数据文件;
.myi,索引文件。
merge数据表是一个逻辑结构,代表一组结构完全相同的myisam数据表构成的集合。它在文件系统中有二个文件,分别是:
.frm,结构定义文件;
.mrg,构成merge表的myisam数据表清单,每个myisam数据表名占一行。也就是说可通过改变该表的内容来改变merge数据表的结构。修改前请先刷新缓存(flush tables),但不建议这样修改merge数据表。
bdb数据表用两个文件来表示,分别是:
.frm,结构定义文件;
.db,数据表数据和索引文件
innodb由于采用表空间的概念来管理数据表,所以它只有一个与数据表对应.frm文件,同一目录下的其它文件表示为表空间,存储数据表的数据和索引。
heap数据表是一个存在于内存中的表,所以它的数据和索引都存在于内存中,文件系统中只有一个.frm文件,以定义结构。
了解mysql数据表在文件系统中表现形式后,我们可知道,创建、修改或删除数据表,其实就是对这些文件进行操作。例如一些数据表(除innodb和heap数据表外),我们可直接在文件系统中删除相应的文件来删除数据表。
% cd datadir
% rm -f mydb/mydb.*
以上命令可删除mydb数据库中的mydb数据表。
