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。
4. MySQL 数据库物理文件存放位置?
使用如下命令:
show global variables like "%datadir%";
2台 MySql的datadir 并不相同。
5. 如果更改默认的位置
打开MySql 安装文件夹,然后找到my-de 文件,查找 datadir 的设置。
如果想修改数据库文件的存储位置,可以直接在这里修改。然后,重启MySql 即可。
如果想对数据库进行搬迁,只需要复制data 这个文件夹,覆盖新环境下的data文件就可以了。