Memory存储引擎

MySQL引擎之Memory

Memory存储引擎也称HEAP存储引擎,所有的数据都保存在内存中,如果MySQL服务重启,数据将会丢失,但是表的结构会保存下来

功能特点

  • 支持HASH索引和BTree索引(默认HASH索引)
  • 所有字段都为固定长度,例如varchar(10)=char(10)
  • 不支持BLOBTEXT等大字段
  • Memory存储引擎使用表级锁

如何选择存储引擎

  • 如果要提供提交、回滚、崩溃恢复能力的事物安全(ACID兼容)能力,并要求实现并发控制,InnoDB是一个好的选择
  • 如果数据表主要用来插入和查询记录,则MyISAM引擎能提供较高的处理效率
  • 如果只是临时存放数据,数据量不大,并且不需要较高的数据安全性,可以选择将数据保存在内存中的Memory引擎,MySQL中使用该引擎作为临时表,存放查询的中间结果
  • 大部分情况下,InnoDB是正确的选择,可以简单地归纳为一句话“除非需要用到某些InnoDB不具备的特性,并且没有其他办法可以替代,否则都应该优先选择InnoDB引擎
    • 参考条件
      • 事务
        如果应用需要事务支持,那么InnoDB(或者XtraDB)是目前最稳定并且经过验证的选择
      • 备份
        如果可以定期地关闭服务器来执行备份,那么备份的因素可以忽略。反之,如果需要在线热备份,那么选择InnoDB就是基本的要求
      • 崩溃恢复
        MyISAM崩溃后发生损坏的概率比InnoDB要高很多,而且恢复速度也要慢

应用举例

• 日志型应用 —— 用MyISAM
• 只读或者大部分情况下只读的表 —— 用MyISAM
• 订单处理 —— 用InnoDB

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员陈_明勇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值