MySql 的每个数据库都对应存放在一个与数据库同名的文件夹中,MySql 数据库文件包括MySql 所创建的数据库文件和所用存储引擎创建的数据表文件。




MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_MySQL 保存表主键的数据在哪张表里


1、MySql 创建并管理的数据库文件

.frm文件:存储数据表的框架结构,文件名与表名相同,每个表对应一个同名frm文件,与操作系统和存储引擎无关,即不管MySql 运行在何种操作系统上,使用何种存储引擎,都有这个文件。

除了必有的.frm文件,根据MySql 所使用的存储引擎的不同(MySQL常用的两个存储引擎是MyISAM和InnoDB),存储引擎会创建各自不同的数据库文件。

2、MyISAM数据库表文件

.MYD文件:即MY Data,表数据文件。

.MYI文件:即MY Index,索引文件。

.log文件:日志文件。

3、InnoDB采用表空间(tablespace)来管理数据,存储表数据和索引

InnoDB数据库文件(即InnoDB文件集,ib-file set):

  • ibdata1、ibdata2等:系统表空间文件,存储InnoDB系统信息和用户数据库表数据和索引,所有表共用。
  • .ibd文件:单表表空间文件,每个表使用一个表空间文件(file per table),存放用户数据库表数据和索引。
  • 日志文件: ib_logfile1、ib_logfile2。


MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_MySQL 保存表主键的数据在哪张表里_02


4. MySQL 数据库物理文件存放位置?

使用如下命令:

show global variables like "%datadir%";


MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_mysql 创建表_03


2台 MySql的datadir 并不相同。


MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_mysql 创建表_04


MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_mysql修改数据_05


5. 如果更改默认的位置

打开MySql 安装文件夹,然后找到my-default.ini 文件,查找 datadir 的设置。


MySQL 保存表主键的数据在哪张表里 mysql创建的表保存在哪里_mysql导入frm文件_06


如果想修改数据库文件的存储位置,可以直接在这里修改。然后,重启MySql 即可。

如果想对数据库进行搬迁,只需要复制data 这个文件夹,覆盖新环境下的data文件就可以了。