zoukankan      html  css  js  c++  java
  • Mysql 存储引擎中InnoDB与MyISAM差别(网络整理)

    1。 事务处理
    innodb 支持事务功能,myisam 不支持。
    Myisam 的运行速度更快,性能更好。

    2,select ,update ,insert ,delete 操作
    MyISAM:假设运行大量的SELECT。MyISAM是更好的选择
    InnoDB:假设你的数据运行大量的INSERT或UPDATE,出于性能方面的考虑。应该使用InnoDB表

    3。锁机制不同
    InnoDB 为行级锁,myisam 为表级锁。
    注意:当数据库无法确定所找的行时。也会变为锁定整个表。
    如: update table set num = 10 where username like "%test%";

    4,查询表的行数不同
    MyISAM:select count(*) from table,MyISAM仅仅要简单的读出保存好的行数,注意的是。当count(*)语句包括   where条件时,两种表的操作是一样的

    InnoDB  InnoDB 中不保存表的详细行数,也就是说。运行select count(*) from table时。InnoDB要扫描一遍整个表来计算有多少行

    5,物理结构不同
    MyISAM :每一个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字開始,扩展名指出文件类型。

      .frm文件存储表定义。

      数据文件的扩展名为.MYD (MYData)。
      索引文件的扩展名是.MYI (MYIndex)

    InnoDB:基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的大小仅仅受限于操作系统文件的大小,一般为 2GB

    6,anto_increment 机制不同
     更好和更快的auto_increment处理


    其它:为什么MyISAM会比Innodb 的查询速度快。
    INNODB在做SELECT的时候,要维护的东西比MYISAM引擎多非常多;
    1)数据块,INNODB要缓存,MYISAM仅仅缓存索引块,  这中间还有换进换出的降低; 
    2)innodb寻址要映射到块,再到行。MYISAM 记录的直接是文件的OFFSET,定位比INNODB要快
    3)INNODB还须要维护MVCC一致;尽管你的场景没有,但他还是须要去检查和维护
    MVCC ( Multi-Version Concurrency Control )多版本号并发控制 
    InnoDB:通过为每一行记录加入两个额外的隐藏的值来实现MVCC,这两个值一个记录这行数据何时被创建。另外一个记录这行数据何时过期(或者被删除)。可是InnoDB并不存储这些事件发生时的实际时间,相反它仅仅存储这些事件发生时的系统版本。

    这是一个随着事务的创建而不断增长的数字。每一个事务在事务開始时会记录它自己的系统版本。

    每一个查询必须去检查每行数据的版本与事务的版本是否同样。

    让我们来看看当隔离级别是REPEATABLE READ时这样的策略是怎样应用到特定的操作的:

      SELECT InnoDB必须每行数据来保证它符合两个条件:
      1、InnoDB必须找到一个行的版本号,它至少要和事务的版本号一样老(也即它的版本号号不大于事务的版本号号)。这保证了无论是事务開始之前,或者事务创建时,或者改动了这行数据的时候,这行数据是存在的。
      2、这行数据的删除版本号必须是没有定义的或者比事务版本号要大。这能够保证在事务開始之前这行数据没有被删除。

    所以。InnoDB 用于数据完整性/写性能要求比較高的应用. MyISAM 适合查询应用。


    假设不是对事务要求很的强,高并发写推荐选择MyISAM。理由例如以下:

    1. MyISAM的索引和数据是分开的。而且索引是有压缩的,内存使用率就相应提高了不少。能载入很多其它索引,而Innodb是索引和数据是紧密捆绑的。没有使用压缩从而会造成Innodb比MyISAM体积庞大不小。
    2. InnoDB存储引擎在插入数据时会花很多其它的开销在维护完整性、维持事务上,所以效率比MyISAM低;
    3. 依据题主的描写叙述,主要是插入数据。而且仅仅有一张表,后期对该表的操作也主要是查询吧,就查询速度而言,MyISAM比InnoDB更优越。而且还有MyISAM索引。能够非常好的优化查询速度。


  • 相关阅读:
    关于Python的装饰器(1)
    Linux环境配置备忘
    Spark实施备忘
    RuntimeError: Python is not installed as a framework 错误解决方案
    使用正则表达式验证素数
    Linux终极shell-zsh的完美配置方案!——oh-my-zsh
    终极之shell-zsh全解析
    linux下IPTABLES配置详解
    一款堪称完美的编程字体Source Code Pro
    Linux中一个文件10行内容,如何输出5-8内容到屏幕
  • 原文地址:https://www.cnblogs.com/blfbuaa/p/6863076.html
Copyright © 2011-2022 走看看