mysql引擎文件_Mysql引擎文件

一、常用的两种引擎

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

索引方式

默认引擎版本

简述

MyISAM引擎

非聚集索引方式

5.5版本之前

性能极佳,但却不支持事务处理(transaction)

INNODB引擎

聚集索引方式

5.5版本

和MyISAM相比,它支持ACID兼容的事务

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

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

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

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

88b915a96c9c3b1293551a0e3950afef.png

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

mysql> CREATE DATABASE xuzhijieDB;

-- ------返回结果:Query OK, 1 row affected (0.00 sec)

e55bbe2a7b5867162d5f527285d299fe.png

③双击进入这个数据库,发现里面是有个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这个文件我们会发现多出了几个文件:

02567d676b1a7b16ae3253335685bb90.png

⑤我们在使用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)

e117236479aea7293a5fe6e943830447.png

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

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

①FRM文件

我们上面的例子中两个数据表的字段均是一致的,也就是说两个数据表xuzhijietest和xuzhijietest2的结构是一样的。

FRM文件时用来存储数据表的结构的,下图之所以FRM文件大小一直是因为这两个表的结构一致。

实时上,FRM指的就是③还和⑤中的数据表创建语句,并用二进制代码储存(感兴趣可以用sublime打开看看,反正你也看不懂)

c35717494e7984ca92afed282296b755.png

②其他文件:

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

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

e0c252f2779523911ecfe69982bc17b2.png

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

MyiSAM的查询性能由于Innodb

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

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

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

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

bc49810a948b985629d45563686f69dc.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值