myisam 和 innodb引擎的区别

1.这是两种表的类型。基本差别: myisam 类型不支持事务处理等高级处理,而innodB支持。myisam类型的表强调性能,其执行数度比 InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已经外部键等高级数据库功能

MyISAM 是MySQL中默认的存储引擎,一般来说不是有太多人关心这个东西。决定使用什么样的存储引擎是一个很tricky的事情,但是还是值我们去研究一下,这里的文章只考虑 MyISAM 和InnoDB这两个,因为这两个是最常见的。

下面先思考回答一些问题:

  • 你的数据库有外键吗?
  • 你需要事务支持吗?
  • 你需要全文索引吗?
  • 你经常使用什么样的查询模式?
  • 你的数据有多大?
  • 如果你需要事务处理或是外键,那么InnoDB 可能是比较好的方式。如果你需要全文索引,那么通常来说 MyISAM是好的选择,因为这是系统内建的,然而,我们其实并不会经常地去测试两百万行记录。所以,就算是慢一点,我们可以通过使用Sphinx从 InnoDB中获得全文索引。
  • 数据的大小,是一个影响你选择什么样存储引擎的重要因素,大尺寸的数据集趋向于选择InnoDB方式,因为其支持事务处理和故障恢复。数据库的在小 决定了故障恢复的时间长短,InnoDB可以利用事务日志进行数据恢复,这会比较快。而MyISAM可能会需要几个小时甚至几天来干这些事,InnoDB 只需要几分钟。

    您操作数据库表的习惯可能也会是一个对性能影响很大的因素。比如: COUNT() 在 MyISAM 表中会非常快,而在InnoDB 表下可能会很痛苦。而主键查询则在InnoDB下会相当相当的快,但需要小心的是如果我们的主键太长了也会导致性能问题。大批的inserts 语句在MyISAM下会快一些,但是updates 在InnoDB 下会更快一些——尤其在并发量大的时候。



MyISAMInnoDBMySQL中常用的两种存储引擎,它们在功能和性能上有一些区别。 1. 事务支持:InnoDB支持事务处理,而MyISAM不支持。事务是一组操作的原子单位,可以保证数据的一致性和完整性。如果你需要使用事务来控制并发访问或者实现数据回滚等功能,那么InnoDB是更好的选择。 2. 锁级别:MyISAM使用表级锁定,而InnoDB支持行级锁定。表级锁定意味着当一个线程对表进行修改时,其他线程无法对同一表进行修改。而行级锁定允许多个线程同时修改表中的不同行,提高了并发性能。 3. 外键支持:InnoDB支持外键约束,而MyISAM不支持。外键是用来定义表与表之间的关系的约束条件,可以保证数据的一致性和完整性。如果你需要在数据库层面实现数据完整性的控制和关联查询等功能,那么InnoDB是更好的选择。 4. 崩溃恢复:InnoDB具有崩溃恢复的能力,可以在数据库发生故障或者断电等情况下恢复数据的一致性。而MyISAM不具备这种能力,可能会导致数据丢失或者损坏。 5. 全文索引:MyISAM支持全文索引,而InnoDBMySQL 5.6版本之前不支持全文索引。全文索引可以提高对文本内容的搜索效率。 综上所述,如果你需要事务支持、并发性能较高、数据完整性控制和崩溃恢复等特性,那么InnoDB是更好的选择。如果你主要进行读操作,并且对于事务和数据完整性要求不高,那么MyISAM可能是一个更简单和高效的选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值