您的位置:首页 > 数据库 > MySQL

mysql数据表引擎InnoDB和MyISAM的特点

2015-05-31 18:46 525 查看

1、MyISAM表引擎特点

(1)MyISAM 是MySQL缺省存贮引擎

(2)具有检查和修复表格的大多数工具. 

(3)表格可以被压缩

(4)支持全文搜索.

(5)不是事务安全的.如果事物回滚将造成不完全回滚,不具有原子性。

(6)不支持外键。

(7)如果执行大量的SELECT,MyISAM是更好的选择。

(8)每张MyISAM 表被存放在三个文件 :frm 文件存放表格定义,数据文件是MYD (MYData),索引文件是MYI (MYIndex) 引伸。

(9)表是保存成文件的形式,在跨平台的数据转移中使用MyISAM存储会省去不少的麻烦

(10)较好的键统计分布

(11)较好的auto_increment处理

总结:

读取操作在效率上要优于InnoDB.小型应用使用MyISAM是不错的选择.并发性弱于InnoDB。

2、innodb表引擎特点

 (1)提供了具有事务提交、回滚和崩溃修复能力的事务安全型表。

(2)提供了行锁,提供与 Oracle 类型一致的不加锁读取。

(3)表中不需要扩大锁定,因为 InnoDB 的列锁定适宜非常小的空间。

(4)提供外键约束。

(5)设计目标是处理大容量数据库系统,它的 CPU 利用率是其它基于磁盘的关系数据库引擎所不能比的。

(6)在主内存中建立其专用的缓冲池用于高速缓冲数据和索引。 

(7)把数据和索引存放在表空间里,可能包含多个文件,这与其它的不一样,举例来说,在MyISAM 中,表被存放在单独的文件中。

(8)表的大小只受限于操作系统的文件大小,一般为 2 GB。

(9)所有的表都保存在同一个数据文件 ibdata1 中(也可能是使用独立的表空间文件的多个文件,使用共享表空间时比较不好备份单独的表),免费的方案可以是拷贝数据文件、备份 binlog,或者用 mysqldump。

总结:

这些特性均提高了多用户并发操作的性能表现。

注意:

对于支持事物的InnoDB类型的表,影响速度的主要原因是AUTOCOMMIT默认设置是打开的,而且程序没有显式调用BEGIN 开始事务,导致每插入一条都自动Commit,严重影响了速度。即使autocommit打开也可以,可以在执行sql前调用begin,多条sql形成一个事务;或者不打开AUTOCOMMIT配置,将大大提高性能。

3、MyISAM表和InnoDB表差别

(1)InnoDB类型支持事务处理,MyISAM类型不支持

(2)InnoDB不支持FULLTEXT类型的索引,MyISAM支持。

(3)InnoDB提供了行锁,MyISAM写入时锁表。

InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”

(4)InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行;但是MyISAM只要简单的读出保存好的行数即可。
当count(*)语句包含 where条件时,两种表的操作是一样的。

(5)DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除,MyISAM重建表。

(6)InnoDB不支持LOAD TABLE FROM MASTER操作(表的拷贝从主服务器转移到从属服务器);MyISAM表支持。

解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。

(7)对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引;但是在MyISAM表中,可以和其他字段一起建立联合索引。

4、事务测试

(1)事务表创建

使用启动mysql命令如下,只影响到create语句

mysqld-max-nt --standalone --default-table-type=InnoDB

创建表命令如下:

use test;

drop table if exists tn;

create table tn (a varchar(10));

查看表的类型

show create table tn;

(2)事务表切换

临时改变默认表类型可以用:

set table_type=InnoDB;

show variables like 'table_type';

 

可以执行以下命令来切换非事务表到事务表(数据不会丢失):

alter table tablename type=innodb;

(3)事务使用

创建表默认是 myisam表类型。

对不支持事务的表做start/commit操作没有任何效果,在执行commit前已经提交,测试:

执行一个msyql:

use test;

drop table if exists tm;

create table tn (a varchar(10)) type=myisam;

drop table if exists tn;

create table ty (a varchar(10)) type=innodb;

begin;

insert into tm values('a');

insert into tn values('a');

select * from tm;

select * from tn;

都能看到一条tm表的记录

执行另一个mysql:

use test;

select * from tm;

select * from tn;

只有tm能看到一条记录

只有在原来那边 commit tn表;

才都能看到tn表的记录。

5、性能测试

针对业务类型来选择使用恰当的数据引擎,才能最大的发挥MySQL的性能优势.

MyISAM引擎与InnoDB引擎简单性能测试如下:

[硬件配置]

CPU : AMD2500+ (1.8G)

内存: 1G/现代

硬盘: 80G/IDE

[软件配置]

OS : Windows XP SP2

SE : PHP5.2.1

DB : MySQL5.0.37

Web: IIS6

[MySQL表结构]

CREATE TABLE `myisam` (

  `id` int(11) NOT NULL auto_increment,

  `name` varchar(100) default NULL,

  `content` text,

  PRIMARY KEY  (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=gbk;

CREATE TABLE `innodb` (

  `id` int(11) NOT NULL auto_increment,

  `name` varchar(100) default NULL,

  `content` text,

  PRIMARY KEY  (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=gbk;

[数据内容]

$name = "chenjiayi";

$content = "MySQL支持数个存储引擎作为对不同表的类型的处理器。MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎:? MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。MyISAM在所有MySQL配置里被支持,它是默认的存储引擎,除非你配置MySQL默认使用另外一个引擎。 ?MEMORY存储引擎提供“内存中”表。MERGE存储引擎允许集合将被处理同样的MyISAM表作为一个单独的表。就像MyISAM一样,MEMORY和MERGE存储引擎处理非事务表,这两个引擎也都被默认包含在MySQL中。
释:MEMORY存储引擎正式地被确定为HEAP引擎。? InnoDB和BDB存储引擎提供事务安全表。BDB被包含在为支持它的操作系统发布的MySQL-Max二进制分发版里。InnoDB也默认被包括在所有MySQL 5.1二进制分发版里,你可以按照喜好通过配置MySQL来允许或禁止任一引擎。?EXAMPLE存储引擎是一个“存根”引擎,它不做什么。你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。";

[插入数据-例1] (innodb_flush_log_at_trx_commit=1)(每次插入数据的时候会自动提交)

MyISAM 1W(行数):3/s

InnoDB 1W:219/s

MyISAM 10W:29/s

InnoDB 10W:2092/s

MyISAM 100W:287/s

InnoDB 100W:没敢测试

[插入数据-2] (innodb_flush_log_at_trx_commit=0)(每次插入数据的时候都不会提交)

MyISAM 1W:3/s

InnoDB 1W:3/s

MyISAM 10W:30/s

InnoDB 10W:29/s

MyISAM 100W:273/s

InnoDB 100W:423/s

[插入数据3] (innodb_buffer_pool_size=1024M)

InnoDB 1W:3/s

InnoDB 10W:33/s

InnoDB 100W:607/s

[插入数据4] (innodb_buffer_pool_size=256M, innodb_flush_log_at_trx_commit=1, set autocommit=0)

InnoDB 1W:3/s

InnoDB 10W:26/s

InnoDB 100W:379/s

【分析】

(1)innodb_flush_log_at_trx_commit  (日志提交,这个选项很管用) 

抱怨Innodb比MyISAM慢 100倍?那么你大概是忘了调整这个值。默认值1的意思是每一次事务提交或事务外的指令都需要把日志写入(flush)硬盘,这是很费时的。特别是使用电 池供电缓存(Battery backed up cache)时。设成2对于很多运用,特别是从MyISAM表转过来的是可以的,它的意思是不写入硬盘而是写入系统缓存。日志仍然会每秒flush到硬 盘,所以你一般不会丢失超过1-2秒的更新。设成0会更快一点,但安全方面比较差,如果MySQL挂了可能会丢失事务的数据。而值2只会在整个操作系统
挂了时才可能丢数据。 

可以看出在MySQL 5.0里面,MyISAM和InnoDB存储引擎性能差别并不是很大,针对InnoDB来说,影响性能的主要是 innodb_flush_log_at_trx_commit 这个选项,如果设置为1的话,那么每次插入数据的时候都会自动提交,导致性能急剧下降,应该是跟刷新日志有关系,设置为0效率能够看到明显提升,当然,同样你可以SQL中提交“SET AUTOCOMMIT = 0”来设置达到好的性能。

(2)innodb_buffer_pool_size(作用是缓存表的索引(主要是innodb表)和数据,插入数据时的缓冲)

如果用Innodb,那么这是一个重要变量。相对于MyISAM来说,Innodb对于buffer size更敏感。MySIAM可能对于大数据量使用默认的key_buffer_size也还好,但Innodb在大数据量时用默认值就感觉在爬了。 Innodb的缓冲池会缓存数据和索引,所以不需要给系统的缓存留空间,如果只用Innodb,可以把这个值设为内存的70%-80%。和 key_buffer相同,如果数据量比较小也不怎么增加,那么不要把这个值设太高也可以提高内存的使用率。

配置修改如下(操作系统内存的70%-80%最佳,如果系统内存8G):

innodb_buffer_pool_size = 6G

此外,这个参数是非动态的,要修改这个值,需要重启mysqld服务。所以设置的时候要非常谨慎。并不是设置的越大越好。设置的过大,会导致system的swap空间被占用,导致操作系统变慢,从而减低sql查询的效率。

另外,还听说通过设置innodb_buffer_pool_size能够提升InnoDB的性能,但是测试发现没有特别明显的提升。

6、总结

InnoDB自身很多良好的特点,比如事务支持、存储过程、视图、行级锁定等等。
在并发很多的情况下,InnoDB的表现要比MyISAM强很多。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: