mysql的存储引擎

文章介绍了MySQL的几种主要存储引擎,包括InnoDB(默认支持事务和行级锁),MyISAM(不支持事务),Archive(适合日志存储),Blackhole(丢弃所有数据但可用于复制),CSV(数据交换),Memory(快速访问但不持久化),以及Federated(跨服务器访问)。InnoDB和MyISAM的对比显示,InnoDB更适合高并发和事务处理,而MyISAM则更轻量级。
摘要由CSDN通过智能技术生成

一、查看存储引擎

1.查看mysql有哪些存储引擎

SHOW engines;

在这里插入图片描述
2.查看默认得存储引擎

SHOW VARIABLES LIKE '%storage_engine%';

在这里插入图片描述

二.各种引擎介绍

2.1.InnoDB存储引擎

  • 大于等于5.5之后,默认采用InnoDB引擎。
  • oInnoDB是MySQL的默认事务型引擎,它被设计用来处理大量的短期(short-lived)事务。可以确保事务的完整提交(Commit)和回滚(Rollback)。除了增加和查询外,还需要更新,删除操作,那么,应优选选择InnoDB存储引擎.除非有非常特别的原因需要使用其他的存储引擎,否则应该优先考虑InnoDB引擎。

2.2.MyISAM存储引擎

  • MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务和行级锁,有一个毫无疑问的缺陷就是崩溃后无法安全恢复.5.5之前默认的存储引擎

2.3.Archive引擎

  • Archive档案存储引擎只支持INSERT和SELECT操作,在MySQL5.1之前不支持索引。
  • Archive表适合日志和数据采集(档案)类应用。
  • 根据英文的测试结论来看,Archive表比MyISAM表要小大约75%,比支持事务处理的InnoDB表小大约83%。

2.4.Blackhole引擎

  • Blackhole引擎没有实现任何存储机制,它会丢弃所有插入的数据,不做任何保存。
  • 但服务器会记录Blackhole表的日志,所以可以用于复制数据到备库,或者简单地记录到日志。但这种应用方式会碰到很多问题,因此并不推荐。

2.5.CSV引擎

  • CSV引擎可以将普通的CSV文件作为MySQL的表来处理,但不支持索引。
  • CSV引擎可以作为一种数据交换的机制,非常有用。
  • CSV存储的数据直接可以在操作系统里,用文本编辑器,或者excel读取。

2.6.Memory引擎

  • 如果需要快速地访问数据,并且这些数据不会被修改,重启以后丢失也没有关系,那么使用Memory表是非常有用。
  • Memory表至少比MyISAM表要快一个数量级。

2.7.Federated引擎

  • Federated引擎是访问其他MySQL服务器的一个代理,尽管该引擎看起来提供了一种很好的跨服务器的灵活性,但也经常带来问题,因此默认是禁用的。

2.8innodb和MyIsam对比
myisam: 不支持事务 不支持行锁(任何更新操作都会锁表,不支持高并发) 不支持外键
innodb: 支持事务 支持行锁(锁当前记录,适合高并发) 支持外键

对比项innodbmyisam
事务支持事务不支持事务
行锁支持行锁(锁当前记录,适合高并发)不支持行锁(任何更新操作都会锁表,不支持高并发)
外键支持不支持
缓存不仅缓存索引还要缓存真实数据,对内存要求较高,而且内存大小对性能有决定性的影响只缓存索引,不缓存真实数据
关注点高并发,事务消耗小,节省资源,简单业务
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值