• mysql中engine=innodb和engine=myisam的区别


    1/ISAM 
    ISAM是一个定义明确且历经时间考验的数据表格管理方法,它在设计之时就考虑到数据库被查询的次数要远大于更新的次数。因此,ISAM执行读取操作的速度很快,而且不占用大量的内存和存储资源。ISAM的两个主要不足之处在于,它不支持事务处理,也不能够容错:如果你的硬盘崩溃了,那么数据文件就无法恢复了。如果你正在把ISAM用在关键任务应用程序里,那就必须经常备份你所有的实时数据,通过其复制特性,MySQL能够支持这样的备份应用程序。

    3/MyISAM
    MyISAM 在MySQL中是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的 顺序访问方法) 的缩写,它是存储记录和文件的标准方法.与其他存储引擎比较,MyISAM具有检查和修复表格的大多数工具. MyISAM表格可以被压缩,而且它们支持全文搜索.它们不是事务安全的,而且也不支持外键。如果事物回滚将造成不完全回滚,不具有原子性。如果执行大量 的SELECT,MyISAM是更好的选择。
     
     MyIASM是IASM表的新版本,有如下扩展:
      二进制层次的可移植性。
      NULL列索引。
      支持大文件。
      更好的索引压缩。
      更好的键吗统计分布。
      更好和更快的auto_increment处理。
    3/InnoDB  
    它提供了事务控制能力功能,它确保一组命令全部执行成功,或者当任何一个命令出现错误时所有命令的结果都被回退,可以想像在电子银行中事务控制能力是非常重要的。支持COMMIT、ROLLBACK和其他事务特性。最新版本的Mysql已经计划移除对BDB的支持,转而全力发展InnoDB。如果需要一个事务安全的存储引擎,建议使用它.如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB。
     对于支持事物的InnoDB类型的标,影响速度的主要原因是AUTOCOMMIT默认设置是打开的,而且程序没有显式调用BEGIN 开始事务,导致每插入一条都自动Commit,严重影响了速度。可以在执行sql前调用begin,多条sql形成一个事物(即使autocommit打 开也可以),将大大提高性能。
      
    以下是一些细节和具体实现的差别:

    1.InnoDB不支持FULLTEXT类型的索引。
    2.InnoDB中不保存表的
    具体行数,也就是说,执行select count(*) from
    table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含
    where条件时,两种表的操作是一样的。
    3.对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。
    4.DELETE
    FROM table时,InnoDB不会重新建立表,而是一行一行的删除。
    5.LOAD TABLE FROM
    MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。

    6.如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update
    table set num=1 where name like “�a%”
    7. 创建表时如果不指定type则默认为myisam,不支持事务。
    可以用 show create table tablename 命令看表的类型。
    8. 对不支持事务的表做start/commit操作没有任何效果,在执行commit前已经提交,测试:
    执行一个msyql:
    use test;
    drop table if exists tn;
    create table tn (a varchar(10)) type=myisam;
    drop table if exists ty;
    create table ty (a varchar(10)) type=innodb;
    begin;
    insert into tn values('a');
    insert into ty values('a');
    select * from tn;
    select * from ty;
    都能看到一条记录
    执行另一个mysql:
    use test;
    select * from tn;
    select * from ty;
    只有tn能看到一条记录
    然后在另一边
    commit;
    才都能看到记录。
    9. 可以执行以下命令来切换非事务表到事务(数据不会丢失),innodb表比myisam表更安全:
       alter table tablename type=innodb;
    10. innodb表不能用repair table命令和myisamchk -r table_name
    但可以用check table,以及mysqlcheck [OPTIONS] database [tables]
    11. 启动mysql数据库的命令行中添加了以下参数可以使新发布的mysql数据表都默认为使用事务(
    只影响到create语句。)
    --default-table-type=InnoDB
    测试命令:
    use test;
    drop table if exists tn;
    create table tn (a varchar(10));
    show create table tn;
    12. 临时改变默认表类型可以用:
    set table_type=InnoDB;
    show variables like 'table_type';
    或:
    c:/mysql/bin/mysqld-max-nt --standalone --default-table-type=InnoDB


  • 相关阅读:
    飞入飞出效果
    【JSOI 2008】星球大战 Starwar
    POJ 1094 Sorting It All Out
    POJ 2728 Desert King
    【ZJOI 2008】树的统计 Count
    【SCOI 2009】生日快乐
    POJ 3580 SuperMemo
    POJ 1639 Picnic Planning
    POJ 2976 Dropping Tests
    SPOJ QTREE
  • 原文地址:https://www.cnblogs.com/Gile/p/4383831.html
Copyright © 2020-2023  润新知