mysql的各个引擎

1、InnoDB存储引擎
InnoDB是MySQL的默认事务型引擎,它被设计用来处理大量的短期(short-lived)事务。除非有非常特别的原因需要使用其他的存储引擎,否则应该优先考虑InnoDB引擎。
 
2、MyISAM存储引擎
MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务和行级锁,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。
 
3、Archive引擎
Archive档案存储引擎只支持INSERT和SELECT操作,在MySQL5.1之前不支持索引。
Archive表适合日志和数据采集类应用。
根据英文的测试结论来看,Archive表比MyISAM表要小大约75%,比支持事务处理的InnoDB表小大约83%。
 
4、Blackhole引擎
Blackhole引擎没有实现任何存储机制,它会丢弃所有插入的数据,不做任何保存。但服务器会记录Blackhole表的日志,所以可以用于复制数据到备库,或者简单地记录到日志。但这种应用方式会碰到很多问题,因此并不推荐。 
 
5、CSV引擎 
CSV引擎可以将普通的CSV文件作为MySQL的表来处理,但不支持索引。
CSV引擎可以作为一种数据交换的机制,非常有用。
CSV存储的数据直接可以在操作系统里,用文本编辑器,或者excel读取。
 
6、Memory引擎
如果需要快速地访问数据,并且这些数据不会被修改,重启以后丢失也没有关系,那么使用Memory表是非常有用。Memory表至少比MyISAM表要快一个数量级。
 
7、Federated引擎
Federated引擎是访问其他MySQL服务器的一个代理,尽管该引擎看起来提供了一种很好的跨服务器的灵活性,但也经常带来问题,因此默认是禁用的。
 
 

MySQL中支持多种不同的存储引擎,每种存储引擎具有不同的特性和适用场景。以下是各个存储引擎的主要区别: 1. MyISAM:MyISAM是MySQL最古老的存储引擎之一。它不支持事务处理和行级锁定,但是具有较高的读取性能,适用于读取频繁、更新不频繁的应用场景。 2. InnoDBInnoDBMySQL中最常用的存储引擎之一。它支持事务处理和行级锁定,具有较好的并发能力和稳定性,适用于高并发、事务性操作频繁的应用场景。 3. Memory:Memory存储引擎是将数据存储在内存中,因此具有非常快的读取和写入性能。但是由于数据存储在内存中,因此对于数据容量和数据持久化要求较高。 4. Archive:Archive存储引擎支持高效的数据压缩和查询,适用于对于数据容量和存储空间要求较高的应用场景。 5. CSV:CSV存储引擎支持将数据以CSV格式存储在文件中,适用于需要将数据导出为CSV格式的应用场景。 6. Blackhole:Blackhole存储引擎将数据写入黑洞,不会实际存储数据。适用于需要将数据写入多个数据表的应用场景。 7. Federated:Federated存储引擎可以通过远程服务器访问数据,适用于需要访问多个服务器上的数据的应用场景。 8. NDB:NDB存储引擎MySQL Cluster的一部分,支持分布式存储和高可用性,适用于对数据可用性要求非常高的应用场景。 每种存储引擎都具有各自的特点和适用场景,开发人员在选择存储引擎时需要根据具体的应用场景和需求进行选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值