1-001:MySQL的存储引擎有哪些?它们之间有什么区别?

火影  金牌会员 | 2025-3-11 12:55:12 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 989|帖子 989|积分 2967

MySQL 存储引擎
├── InnoDB(默认引擎)
│ ├── 事故支持:支持 ACID 和事故(事故日记、回滚、崩溃恢复)
│ ├── 锁机制:支持行级锁,提高并发性能
│ ├── 外键支持:支持外键约束,包管数据一致性
│ ├── 适用场景:OLTP(高并发事故处理)、数据一致性要求高的系统
│ ├── 其他特点:使用 聚簇索引,自适应哈希索引,提高查询速度

├── MyISAM(老牌引擎)
│ ├── 事故支持:不支持事故
│ ├── 锁机制:表级锁,适用于读多写少的场景
│ ├── 外键支持:不支持外键
│ ├── 适用场景:日记系统、数据分析、全文索引(支持 FULLTEXT 索引)
│ ├── 其他特点:查询速度快,但并发写性能差,崩溃后可能导致数据丢失

├── Memory(内存存储引擎)
│ ├── 事故支持:不支持事故
│ ├── 锁机制:表级锁
│ ├── 外键支持:不支持外键
│ ├── 适用场景:暂时表、缓存数据、会话管理
│ ├── 其他特点:数据存储在内存中,速度极快,但 MySQL 关闭后数据丢失

├── Archive(归档存储引擎)
│ ├── 事故支持:不支持事故
│ ├── 锁机制:只支持插入操纵(不支持删除和索引)
│ ├── 外键支持:不支持外键
│ ├── 适用场景:日记存储、历史数据归档
│ ├── 其他特点:高效压缩存储数据,适合存储大量历史数据

├── NDB(Cluster 数据存储引擎)
│ ├── 事故支持:支持事故
│ ├── 锁机制:行级锁
│ ├── 外键支持:不支持外键
│ ├── 适用场景:高可用、高吞吐量的分布式存储(如电信系统)
│ ├── 其他特点:分布式集群架构,可扩展性强

├── CSV(文本存储引擎)
│ ├── 事故支持:不支持事故
│ ├── 锁机制:表级锁
│ ├── 外键支持:不支持外键
│ ├── 适用场景:数据交换、导出 CSV 文件
│ ├── 其他特点:每个表存储为一个 CSV 文件,数据可读性高

└── Federated(远程表存储引擎)
├── 事故支持:取决于远程数据库
├── 适用场景:跨服务器访问数据
├── 其他特点:本地数据库不存储数据,仅通过远程毗连访问

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

火影

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表