MySQL存储引擎InnoDB与Myisam的区别分析

作者:yin 时间:2024-01-18 13:34:50 

MySQL有多种存储引擎:MyISAM、InnoDB、MERGE、MEMORY(HEAP)、BDB(BerkeleyDB)、EXAMPLE、FEDERATED、ARCHIVE、CSV、BLACKHOLE。比较常用的是 MyISAM 和 InnoBD。在MySQL 5.1之前的版本中,默认的搜索引擎是MyISAM,从MySQL 5.5之后的版本中,默认的搜索引擎变更为InnoDB。

两者的优劣可谓是各有千秋。INNODB会支持一些关系数据库的高级功能,如事务功能和行级锁,MYISAM不支持。MYISAM的性能更优,占用的存储空间少。所以,选择何种存储引擎,视具体应用而定。

MyISAM介绍

每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。.frm文件存储表定义。数据文件的扩展名为.MYD (MYData)。

MyISAM表格可以被压缩,而且它们支持全文搜索。不支持事务,而且也不支持外键。如果事物回滚将造成不完全回滚,不具有原子性。在进行updata时进行表锁,并发量相对较小。如果执行大量的SELECT,MyISAM是更好的选择。

MyISAM缓存在内存的是索引,不是数据。而InnoDB缓存在内存的是数据,相对来说,服务器内存越大,InnoDB发挥的优势越大。

优点:查询数据相对较快,适合大量的select,可以全文索引。

缺点:不支持事务,不支持外键,并发量较小,不适合大量update

InnoDB介绍

这种类型是事务安全的。.它与BDB类型具有相同的特性,它们还支持外键。InnoDB表格速度很快。具有比BDB还丰富的特性,因此如果需要一个事务安全的存储引擎,建议使用它。在update时表进行行锁,并发量相对较大。如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表。

优点:支持事务,支持外键,并发量较大,适合大量update

缺点:查询数据相对较快,不适合大量的select

MySQL 存储引擎 MyISAM 与 InnoDB 如何选择?

下面我们分别来看两种存储引擎的区别。

  • 一、InnoDB支持事务,MyISAM不支持,这一点是非常之重要。事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了。

  • 二、MyISAM适合查询以及插入为主的应用,InnoDB适合频繁修改以及涉及到安全性较高的应用

  • 三、InnoDB支持外键,MyISAM不支持

  • 四、MySQL 在 5.1 之前版本默认存储引擎是 MyISAM,5.1 之后版本默认存储引擎是 InnoDB

  • 五、InnoDB不支持FULLTEXT类型的索引

  • 六、InnoDB中不保存表的行数,如select count(*) from table时,InnoDB需要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含where条件时MyISAM也需要扫描整个表

  • 七、对于自增长的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中可以和其他字段一起建立联合索引

  • 八、清空整个表时,InnoDB是一行一行的删除,效率非常慢。MyISAM则会重建表

  • 九、InnoDB支持行锁(某些情况下还是锁整表,如 update table set a=1 where user like '%lee%'

通过以上九点区别,结合个人博客的特点,推荐个人博客系统使用MyISAM,因为在博客里主要操作是读取和写入,很少有链式操作。所以选择MyISAM引擎使你博客打开也页面的效率要高于InnoDB引擎的博客,当然只是个人的建议,大多数博客还是根据实际情况下谨慎选择。

标签:InnoDB,Myisam
0
投稿

猜你喜欢

  • Oracle数据操作和控制语言详解

    2008-01-16 19:18:00
  • 一小时快速入门Python教程

    2023-03-06 04:07:03
  • 详解Django关于StreamingHttpResponse与FileResponse文件下载的最优方法

    2021-04-13 08:17:01
  • mysql 数据库安装经验问题汇总

    2024-01-28 11:55:29
  • python sleep和wait对比总结

    2023-04-30 18:26:04
  • 在Python中操作字符串之rstrip()方法的使用

    2022-03-22 18:34:36
  • 从8个方面优化ASP代码

    2007-09-16 18:01:00
  • Python多继承以及MRO顺序的使用

    2022-04-01 19:35:50
  • FrontPage XP设计教程3——网页的布局

    2008-10-11 12:20:00
  • Oracle中instr函数使用方法

    2023-07-23 19:14:06
  • chatGPT使用及注册过程中常见的一些错误解决方法(所有报错汇总)

    2023-03-02 22:27:23
  • JS FormData对象使用方法实例详解

    2024-02-25 04:54:46
  • Python将列表中的元素转化为数字并排序的示例

    2023-07-06 11:16:11
  • CSS实现垂直居中的5种方法

    2009-03-04 12:53:00
  • Sublime Text3 配置 NodeJs 环境的方法

    2024-04-30 09:58:36
  • Python 中random 库的详细使用

    2022-01-19 05:35:14
  • Python3中对range()逆序的解释

    2023-03-26 10:27:59
  • 最新的关键SQL Server漏洞已被微软证实

    2009-03-16 14:31:00
  • TensorFlow人工智能学习数据合并分割统计示例详解

    2022-01-23 05:14:23
  • Python Excel vlookup函数实现过程解析

    2022-05-24 06:12:07
  • asp之家 网络编程 m.aspxhome.com