MyISAM 是MySQL的默认数据库引擎(5.5以后默认是InnoDB)性能极佳,但不支持事务处理。

InnoDB 是MySQL的数据库常用的数据引擎。

MyISAM 和 InnoDB 两者之间有明显的区别,简单梳理一下:

  1. 事务

    • MyISAM:每次查询具有原子性,执行速度比i快但是不支持事务操作。
    • InnoDB:提供事务、回滚、崩溃修复能力的事务安全(ACID)型数据引擎
  2. 存储
    • MyISAM:每个MyISAM表在磁盘上存储成三个文件。分别是表定义文件(表名xx.frm)、数据文件(表名xx.MYD)、索引文件(表名xxx.MYI)。MyISAM还支持三种不同的存储格式,动态表,静态表,压缩表,存储开销依次变小,执行开销依次增大。
    • InnoDB:属于索引组织表。有两种存储方式,分别是共享表空间和多表空间存储。
    • 共享表空间:所有的表都保存在同一个数据文件中。InnoDB表文件的大小之受限于操作系统文件的大小。InnoDB在存储上需要更多的内存和磁盘空间,他会在主存中建立其专用的缓冲池用于高速存取数据与索引。
    • 多表空间存储:每个表都有一个表空间用于存储每个表的数据和索引 (表名.idb)。
  3. 数据移植、备份、恢复
    • MyISAM:数据是以稳健的形式存储,所以在跨平台的数据转移中会很方便。可以对单个表进行操作。
    • InnoDB:由于多个表保存在同一个文件中,只能拷贝整体文件,备份binlog,或者用mysqldump。
  4. 主键
    • MyISAM:允许没有任何索引和主键 的表存在,索引保存的是行的地址
    • InnoDB:如果没有设置主键或者非空唯一索引,就会自动生成一个6字节的主键(用户不可见),数据是主索引的一部分,附加索引保存的是主索引的值。
  5. 外键
    • MyISAM不支持外键,InnoDB支持。
  6. 索引
    • 全文索引:MyISAM全文索引不支持中文(中文需要sphinx),i也支持了(但可以用sphinx插件支持,效果还不错)
    • 另外,MyISAM索引和数据分离,天生非聚簇索引,最多有一个unique的性质。i的数据文件本身就是主键索引文件,这样的索引被称为聚集索引。
    • MyISAM引擎使用b+tree作为索引结构,叶节点的不存放实际数据,存放实际数据的地址,叫做非聚集索引。
    • InnoDB引擎也是用b+tree作为索引结构,但实现方式与m截然不同。一个重大区别是i的数据文件本身就是索引文件(而MyISAM索引文件是与数据文件分离的,主键索引与其他索引在实现上没有区别),子叶节点的数据域部分保存了完整的行记录,这个b+tree的key是表的主键,这种索引叫做聚集索引。
    • 但是,InnoDB中的其他索引在查询时就没有那么幸运了,需要先在其他索引中查询到对应主键,再在聚集索引中查找对应的行。
    • mysql支持三种锁定级别,行级,页级,表级别
    • MyISAM支持表级锁,读写互相阻塞,读阻塞写,写阻塞读写,读不阻塞读。
    • InnoDB支持行级锁(where 字段是主键),表锁,但InnoDB的行锁也不是绝对的,当在执行一个sql语句且mysql不能确定要扫描的范围时,i同样会全表加锁,当确定范围时会加间隙锁。
      • update table set num = 1 where name like ‘%xxx%’; ---退化表锁
      • update table set num = 1 where name = 123             ---隐式转换 退化表锁
      • update table set num = 1 where id >50  -------------------间隙锁
  7. 隔离级别 
    • MyISAM 无隔离级别 只有表锁。
    • InnoDB 隔离级别 (详见下一篇文章)
  8. auto_increment
    • MyISAM 自动增长列必须是索引,如果是组合索引,自动增长列可以不是一地列,他可以根据前面几列排序递增。
    • InnoDB 自动增长列必须是索引,如果是组合索引必须是组合索引的第一列。
  9. 查询行数
    • MyISAM 保存有表的总行数 select count(*) from a;会直接取出对应值。
    • InnoDB 没有保存,需要遍历整张表。
  10. drop table
    • drop table 的处理方式不一样 m会重新建立表,InnoDB不会重新建立表,而是一行一行的删除。因此速度非常慢,推荐是用truncate table。

MySQL 的两种存储引擎的更多相关文章

  1. Mysql的两种存储引擎以及区别

    一.Mysql的两种存储引擎 1.MyISAM: ①不支持事务,但是整个操作是原子性的(事务具备四种特性:原子性.一致性.隔离性.持久性) ②不支持外键,支持表锁,每次所住的是整张表     MyIS ...

  2. mysql的两种存储引擎

    MySQL 有多种存储引擎,目前常用的是 MyISAM 和 InnoDB 这两个引擎,除了这两个引擎以为还有许多其他引擎,有官方的,也有一些公司自己研发的.这篇文章主要简单概述一下常用常见的 MySQ ...

  3. MYSQL的两种存储引擎区别

    Innodb引擎 Innodb引擎提供了对数据库ACID事务的支持,并且实现了SQL标准的四种隔离级别.该引擎还提供了行级锁和外键约束,它的设计目标是处理大容量数据库系统,它本身其实就是基于MySQL ...

  4. Mysql有两种存储引擎:InnoDB与Myisam

    http://www.cnblogs.com/kevingrace/p/5685355.html

  5. MySQL的两种存储引擎storage engine特点和对比

    MyISAM 优点:快速读取数据, 占用空间小 缺点:不支持事务,外键 (表级别锁) InnoDB 优点:支持事务,外键; 高性能(CPU效率高) 缺点: 慢,占空间 (行级别锁)

  6. MySQL两种存储引擎: MyISAM和InnoDB

    MySQL两种存储引擎: MyISAM和InnoDB 简单总结   MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Me ...

  7. MySQL - 两种存储引擎 (MyISAM PK InnoDB) + MVCC

    总结 1.两种存储引擎各有各的有点,MyISAM专注性能,InnoDB专注事务.两者最大的区别就是InnoDB支持事务,和行锁. 2.InnoDB采用MVCC(Multi-Version Concur ...

  8. mysql 有两种数据库引擎发音

    mysql 有两种数据库引擎 一种是 MyISAM,一种是 InnoDB MyISAM 发音为 "my-z[ei]m"; InnoDB 发音为 "in-no-db&quo ...

  9. mysql中四种存储引擎的区别和选择

    前言 数据库存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建.查询.更新和删除数据.不同的存储引擎提供不同的存储机制.索引技巧.锁定水平等功能,使用不同的存储引擎,还可以 ...

随机推荐

  1. eclipse配置文件出现小红叉,Referenced file contains errors (xml文件第一行小红叉错误)

    原文链接:https://blog.csdn.net/zlj1217/article/details/61432437                                          ...

  2. 服务器的公网ip 和内网ip

    原文地址:https://zhidao.baidu.com/question/814783729071869532.html 服务器公网ip 可以用于域名解析ip,服务器远程登录ip,是最主要的服务器 ...

  3. Java多线程之synchronized和volatile

    概述 用Java来开发多线程程序变得越来越常见,虽然Java提供了并发包来简化多线程程序的编写,但是我们有必要深入研究一下,才能更好的掌握这块知识. 本文主要对Java提供的底层原语synchroni ...

  4. 关于JavaScript的原型继承与原型链

    在讨论原型继承之前,先回顾一下关于创建自定义类型的方式,这里推荐将构造函数和原型模式组合使用,通过构造函数来定义实例自己的属性,再通过原型来定义公共的方法和属性. 这样一来,每个实例都有自己的实例属性 ...

  5. P问题,NP问题,NPC问题学习笔记

    参考:https://www.luogu.org/blog/styx-ferryman/chu-sai-bei-kao-gan-huo-p-wen-ti-np-wen-ti-npc-wen-ti-sh ...

  6. 【python&pycharm的安装使用】

    一.Python3.7安装 1. 运行python3.7.exe 2. 检查是否安装成功:命令窗口输入python -V 二.Pycharm安装 1. 运行pycharm.exe(社区版) 2. 配置 ...

  7. Appium+python自动化-Android夜神模拟器

    前言 Android SDK虽然也自带了模拟器,但是那速度会让你怀疑人生,并且不稳定经常卡死异常.夜神模拟器可以说是android模拟器里面的一个神器. 环境安装 1.官网下载地址:https://w ...

  8. HashMap,ConcurrentHashMap原理。Collection(list,set,map集合区别)。和CAS

    collection里面有什么子类?(list和set是实现了collection接口的.) List: 1.可以允许重复的对象(可重复,有序集合).2.可以插入多个null元素.3.常用的实现类有 ...

  9. 【翻译】浅析为何使用融合CDN是大趋势

    使用传统CDN的用户遇到的新问题 随着云计算时代的快速发展,尤其是流媒体大视频时代的到来,用户在是使用过往CDN节点资源调配将面临很多问题: 问题1: 流媒体时代不局限于静态内容分发,直播点播等视频服 ...

  10. Entry小部件:

    导入tkinter import Tkinter from Tinter import * import tkinter from tinter import * 实例化Tk类 root=tkinte ...