Mysql高级性能优化之存储引擎(二)

存储引擎

概念:
1、MYSQL中的数据用各种不同的技术存储在文件(或内存中);
2、每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的功能和能力;
3、选择不同的技术,能够获得额外的速度或者功能,从而改善你的应用的整体功能;(如果你在研究大量临时数据,可以选择内存存储引擎(能够在内存中存储所有的表格数据);如果需要支持事务处理的数据库(确保食物处理不成功时数据的回退能力),选择只是事务的存储引擎。)
这些不同的技术及配套的相关功能在MYSQL中称为存储引擎。

MYSQL的存储引擎:
MyISAM:
拥有较高的插入,查询速度,但不支持事务
InnoDB :
5.5版本后Mysql的默认数据库,事务型数据库的首选引擎,支持ACID事务,支持行级锁定
BDB:
源自Berkeley DB,事务型数据库的另一种选择,支持COMMIT和ROLLBACK等其他事务特性
Memory :
所有数据置于内存的存储引擎,拥有极高的插入,更新和查询效率。但是会占用和数据量成正比的内存空间。并且其内容会在Mysql重新启动时丢失
Merge :
将一定数量的MyISAM表联合而成一个整体,在超大规模数据存储时很有用
Archive :
非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。Archive拥有高效的插入速度,但其对查询的支持相对较差
Federated: 将不同的Mysql服务器联合起来,逻辑上组成一个完整的数据库。非常适合分布式应用
Cluster/NDB :
高冗余的存储引擎,用多台数据机器联合提供服务以提高整体性能和安全性。适合数据量大,安全和性能要求高的应用
CSV:
逻辑上由逗号分割数据的存储引擎。它会在数据库子目录里为每个数据表创建一个.CSV文件。这是一种普通文本文件,每个数据行占用一个文本行。CSV存储引擎不支持索引。
BlackHole :
黑洞引擎,写入的任何数据都会消失,一般用于记录binlog做复制的中继

查看存储引擎:
show engines;
在这里插入图片描述
Engine :指示引擎的名称。
Support :指示是否已安装引擎,以及它是否是当前会话的默认引擎。
Comment :是一个简短的描述。
Transactions(是否支持事务),XA(事务旨在允许分布式事务,其中事务管理器(应用程序)控制涉及多个资源的事务。这些资源通常是DBMS,但可以是任何类型的资源。)并Savepoints(支持执行)指明引擎是否支持交易,XA交易和交易保存点。

此处转自:
https://mariadb.com/kb/en/library/show-engines/#description
https://www.cnblogs.com/shuaiandjun/p/9992432.html

查看当前使用的存储引擎:
show variables like ‘%storage_engine%’;

MyISAM和InnoDB区别:
1、主键:MyISAM不支持,InnoDB支持
2、事务:MyISAM不支持,InnoDB支持
3、行表锁:MyISAM表锁,InnoDB行锁
4、缓存:
MyISAM只缓存索引,不缓存数据;
InnoDB不仅缓存索引,还缓存数据,对内存要求高,内存的大小对性能有影响。
5、表空间:都小
6、关注点:MyISAM性能,InnoDB事务
7、默认安装:
8、文件结构:
MyISAM:
b.frm:描述表结构文件,字段长度等;
b.MYD(MYData):数据信息文件,存储数据信息(如果采用独立表存储模式);
b.MYI(MYIndex):索引信息文件。
InnoDB:
b.frm:描述表结构文件,字段长度等;
b.ibd:存储数据信息和索引信息。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值