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强很多。
相关文章推荐
- mysql主从复制实现数据库同步
- MySQL 处理重复数据
- MAC下安装与配置MySQL
- MySQL 序列使用
- Mysql-日期转换
- mysql核心类之间关系
- (3)mysql优化之sql语句优化
- mysql 查询执行的流程
- mysql 优化
- windows 下 mysql 5.6 免安装版配置
- mysql 并发控制
- MYSQL--事务处理
- mysql 解决 ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061)
- mysql笔记01
- solr 4.9.1+mysql数据库数据导入
- Mysql JDBC Url参数与异常问题
- mysql的sql语句根据经纬度查询距离排序
- mysql将字符转换成数字
- MySQL 元数据
- mysql基础