Mysql引擎文件

28次阅读

共计 1705 个字符,预计需要花费 5 分钟才能阅读完成。

一、常用的两种引擎

在 MySQL 中用的较多的两种引擎是 MyISAM 引擎和 INNODB 引擎,下面主要围绕这两种引擎展开说明:

索引方式 默认引擎版本 简述
MyISAM 引擎 非聚集索引方式 5.5 版本之前 性能极佳,但却不支持事务处理(transaction)
INNODB 引擎 聚集索引方式 5.5 版本 和 MyISAM 相比,它支持 ACID 兼容的事务

注意:执行引擎的操作对象是表而不是数据库!

二、以表为操作对象的引擎的文件表现:

注:此处以 windos 本地服务器为例:

①我们先在服务器上用 mysql 建立一个数据库: 我们可以先在服务器上的存储位置上找到名为 data 的文件夹,这里存储的是数据库和一些其他文件。每一个文件夹分别代表一个数据库

②下面我们建立一个名字叫做 xuzhijieDB 的数据库:

mysql> CREATE DATABASE xuzhijieDB;
-- ------ 返回结果:Query OK, 1 row affected (0.00 sec)

③双击进入这个数据库,发现里面是有个 db.opt 文件夹, 这是因为我们未在数据库中建立任何东西,下面的操作关系到引擎的概念:

我们先建立一个以 Innodb 为存储引擎的表:

mysql> use xuzhijieDB;
-- --- 返回:Database changed
-- 先选择需要操作的数据库
mysql> CREATE TABLE  xuzhijieTest (country varchar(255) NOT NULL,  address varchar(255) NOT NULL, name varchar(255) NOT NULL,  TELE varchar(255) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;
-- ------- 返回结果 Query OK, 0 rows affected (0.04 sec)
-- 注意创建表后的 ENGINE=InnoDB 更加说明引擎是操作表的而不是操作数据库的!

④打开 local_test 这个文件我们会发现多出了几个文件:

⑤我们在使用 MyISAM 引擎建立一个表,还是观察 xuzhijiedb 的文件变化:

mysql> CREATE TABLE  xuzhijieTest2 (country varchar(255) NOT NULL,  address varchar(255) NOT NULL, name varchar(255) NOT NULL,  TELE varchar(255) NOT NULL) ENGINE=MyiSAM DEFAULT CHARSET=utf8;
-- -------- 返回结果:Query OK, 0 rows affected (0.01 sec)

结果:我们发现数据库使用不同引擎产生的文件类型和个数是不一样的。下面对具体的文件进行说明:

三、Innodb 和 MyiSAM 的文件类型对比:

①FRM 文件

我们上面的例子中两个数据表的字段均是一致的,也就是说两个数据表 xuzhijietest 和 xuzhijietest2 的结构是一样的。
FRM 文件时用来存储数据表的结构的,下图之所以 FRM 文件大小一直是因为这两个表的结构一致。
实时上,FRM 指的就是③还和⑤中的数据表创建语句,并用二进制代码储存(感兴趣可以用 sublime 打开看看,反正你也看不懂)

②其他文件:

我们观察 MyiSAM 引擎产生的一个文件:MYD 文件,它是 0kb 的,这是因为 MYD 是 MyiSAM 用来存储数据的,而上述操作我们只是涉及到表的建立,而并没有给数据表加入数据,所以 MYD 的大小为 0。

下面我们添加数据表中的信息,则由于 MYD 是存储数据的,这样它的大小将变成数据大小而不是 0。

我们可以发现 IBD 文件在这些文件中是最大的,因为它是将数据和索引一起存储的,所以文件较大。

MyiSAM 的查询性能由于 Innodb

事实上,Innodb 的 ibd 文件大,这就意味着查找的时间就会越久,查找会慢这也是为什么 MyiSAM 的查找性能大于 innodb 的原因。

MyiSAM 不支持事务,Innodb 支持事务

索引和数据放于两个文件给 MyiSAM 带来了查询速度的快捷,同时这也导致 MyiSAM 不支持事务,这是由于索引和数据放于两个文件会它们很难达到一致性。

最后我们得到下表的结论:

正文完
 0