Mysql引擎文件

1、经常使用的两种引擎

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

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

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

2、以表为操做对象的引擎的文件表现:

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

①咱们先在服务器上用mysql创建一个数据库:咱们能够先在服务器上的存储位置上找到名为data的文件夹,这里存储的是数据库和一些其余文件。每个文件夹分别表明一个数据库服务器

图片描述

②下面咱们创建一个名字叫作xuzhijieDB的数据库:性能

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

图片描述

③双击进入这个数据库,发现里面是有个db.opt文件夹,这是由于咱们未在数据库中创建任何东西,下面的操做关系到引擎的概念:spa

咱们先创建一个以Innodb为存储引擎的表:code

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)

图片描述

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

3、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不支持事务,这是因为索引和数据放于两个文件会它们很难达到一致性。

最后咱们获得下表的结论:

图片描述

相关文章
相关标签/搜索