MySQL的MyISAM和InnoDB两种存储引擎的区别

1. MyISAM是MySQL5.5版本以前默认的数据库引擎

2.Innodb弥补了MyISAM的一些不足,在5.5版本后成为默认数据库引擎,逐渐取代了MyISAM

MyISAM

  • 1.MyISAM强调性能,每次查询具有原子性不提供事务支持
  • 2.只支持表级锁,select,update,delete,insert语句都会给表自动加锁。MyISAM在同一个表上的读锁和写锁是互斥的,如果既有读请求又有写请求,即使读请求先到,写请求优先级也会更高
  • 3.所以MyISAM不适合于有大量查询和修改并存的情况,那样查询进程会长时间阻塞。因为MyISAM是锁表,在某项读操作比较耗时会使其他写进程饿死
  • 4.MyISAM允许没有任何索引和主键的表存在,不支持外键
  • 5.每个MyISAM表在磁盘上存储成三个文件∶·.frm文件∶存储表定义  .MYD文件∶存储数据●.MYI文件∶存储索引
  • 6.索引和数据分离,这样在内存里可以缓存更多的索引,对查询的性能会更好,适用于那种少量的插入,大量查询的场景

使用MyISAM最常见的就是报表系统

  • 1.基于Hadoop生态,用HDFS来存储数据,然后基于Hive来进行数仓建模,每次Hive跑出来的数据都用Sqoop导出乖MySQl中
  • 2.基于MySQL,搭建J2EE的在线报表查询Web系统,每个报表开发一套代码,写对应的查询SQL,组织数据,按照前端要求的格式返回数据,展现出来一个报表
  • 3.这种报表系统,是最适合MySQL的MyISAM存储引擎的,因为并不需要事务支持,就是在最初的时候一次性批量导入大量数据,然后基于这些属于开始查询

 InnoDB

1.InnoDB支持事务,它的AUTO_COMMIT默认是打开的意味着每条SQL语句都会被默认封装成一个事务,自动提交。由于事务的处理会影响速度,所以最好是把多条SQL语句组成一个事务一起提交,减小数据库多次提交导致的开销,以此提高性能

2.支持行级锁,大幅度提高了多用户并发操作的新能。但是InnoDB的行锁,只是在WHERE的主键(只有带上了主键才会是生效的)是有效的,非主键的WHERE还是会锁全表,所以在写sql语句的时候,需要尽可能地包含主键和索引。

3.支持外键,如果没有设定主键或者非空唯一索引,会自动生成一个6字节的主键(用户不可见)

4.表的所有内容都保存在同一个数据文件中,索引和数据并不分开,InnoDB表的大小只受限于操作系统文件的大小,一般为2GB

5.InnoDB需要更多的内存和存储,它会在主内存中建立其专用的缓冲池用于高速缓冲数据和索引

如果只有查询场景的话,使用MyISAM也并没有什么问题。

 

 

限时福利1:原价 129 元,最后2天仅需 69 元!后天涨价至98元 限时福利2:购课进答疑群专享柳峰(刘运强)老师答疑服务 限时福利3:购课添加助教领取价值 800 元的编程大礼包 为什么需要掌握高性能的MySQL实战? 由于互联网产品用户量大、高并发请求场景多,因此对MySQL的性能、可用性、扩展性都提出了很高的要求。使用MySQL解决大量数据以及高并发请求已经是程序员的必备技能,也是衡量一个程序员能力和薪资的标准之一。 为了让大家快速系统了解高性能MySQL核心知识全貌,我为你总结了「高性能 MySQL 知识框架图」,帮你梳理学习重点,建议收藏! 【课程设计】 课程分为四大篇章,将为你建立完整的 MySQL 知识体系,同时将重点讲解 MySQL 底层运行原理、数据库的性能调优、高并发、海量业务处理、面试解析等。 一、性能优化篇: 主要包括经典 MySQL 问题剖析、索引底层原理和事务与锁机制。通过深入理解 MySQL 的索引结构 B+Tree ,学员能够从根本上弄懂为什么有些 SQL 走索引、有些不走索引,从而彻底掌握索引的使用和优化技巧,能够避开很多实战中遇到的“坑”。 二、MySQL 8.0新特性篇: 主要包括窗口函数和通用表表达式。企业中的许多报表统计需求,如果不采用窗口函数,用普通的 SQL 语句是很难实现的。 三、高性能架构篇: 主要包括主从复制和读写分离。在企业的生产环境中,很少采用单台MySQL节点的情况,因为一旦单个节点发生故障,整个系统都不可用,后果往往不堪设想,因此掌握高可用架构的实现是非常有必要的。 四、面试篇: 程序员获得工作的第一步,就是高效的准备面试,面试篇主要从知识点回顾总结的角度出发,结合程序员面试高频MySQL问题精讲精练,帮助程序员吊打面试官,获得心仪的工作机会。
©️2020 CSDN 皮肤主题: 我行我“速” 设计师:Amelia_0503 返回首页