MySQL 的存储引擎

你可以把 数据库 想象成一个大仓库 ,用来存放数据。存储引擎 就是管理这个仓库的 "不同管家",每个管家管仓库的方法和特长都不一样。


三大"管家"的简单比喻

1. InnoDB 管家 ------ 银行的保险库经理
  • 特点非常严谨、安全、可靠
  • 他怎么管
    • 事务(核心) :比如银行转账,必须"A账户扣钱"和"B账户加钱"两步同时完成或同时失败,绝不会只做一步。InnoDB管家保证操作的"原子性"。
    • 行级锁 :只锁住正在操作的那个货架(某一行数据),其他人可以同时操作其他货架,效率高,不堵
    • 外键:保证仓库里的货物关联正确(比如有"订单"就必须有对应的"客户")。
    • 不怕断电:即使仓库突然停电,他也有账本(日志)可以恢复数据,不会错乱。
  • 适合绝大多数严肃、重要的场景 。比如:网上商城、银行系统、需要用户注册登录的网站(现在默认就用他)
2. MyISAM 管家 ------ 老式图书馆管理员
  • 特点老派、简单、读东西快,但怕写、怕乱
  • 他怎么管
    • 无事务:借书、还书没有严格记录,万一中途出岔子,书可能就丢了。
    • 表级锁 :只要有一个人要在一本书上贴个标签(修改数据),他就把整个图书馆(整张表)锁起来 ,其他人一律等着。人一多就卡
    • 查得快:如果只读不写,他查目录找书特别快。
  • 适合几乎快被淘汰了 。以前用在一些只记录、不修改 的地方,比如网站的文章列表、日志记录。现在基本不推荐用他
3. Memory 管家 ------ 会议室的白板
  • 特点速度极快,但只是临时的
  • 他怎么管
    • 所有数据都写在内存(白板) 上,读写速度像闪电。
    • 但是,一旦数据库重启(散会擦白板),所有数据就全没了
  • 适合临时存放、快速计算 。比如临时存一下网站的在线用户列表。现在这个活通常交给更专业的"白板"------Redis(一种缓存数据库)来做。

一句话总结该选谁

  • 如果你在做一个正经的、需要保存数据的网站或应用 ,闭着眼睛选 InnoDB
  • MyISAM 是过去式,知道有这么个人就行,别用了。
  • Memory 是临时工,有更专业的临时工(如Redis)代替。

核心对比

管家 (引擎) 像什么 最大优点 最大缺点 现在还用吗?
InnoDB 银行经理 安全、可靠、不怕乱 相比MyISAM,纯读时稍占地方 是,绝对主力
MyISAM 老图书馆 只读时查得快 怕写、怕乱、一改就卡 基本不用了
Memory 白板 速度飞快 断电就丢 很少用,有更好的替代品

最终结论:选InnoDB ,它是现在 MySQL 数据库的"标配"和唯一正确的选择。


相关推荐
Logic1014 小时前
《Mysql数据库应用》 第2版 郭文明 实验5 存储过程与函数的构建与使用核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
小二·5 小时前
MyBatis基础入门《十六》企业级插件实战:基于 MyBatis Interceptor 实现 SQL 审计、慢查询监控与数据脱敏
数据库·sql·mybatis
bing.shao5 小时前
Golang WaitGroup 踩坑
开发语言·数据库·golang
专注VB编程开发20年5 小时前
C#内存加载dll和EXE是不是差不多,主要是EXE有入口点
数据库·windows·microsoft·c#
小二·5 小时前
MyBatis基础入门《十二》批量操作优化:高效插入/更新万级数据,告别慢 SQL!
数据库·sql·mybatis
何中应5 小时前
【面试题-6】MySQL
数据库·后端·mysql·面试题
路遥_135 小时前
银河麒麟 V10 安装部署瀚高数据库 HighGoDB 4.5 全流程(统信UOS Server 20同理)
数据库
TDengine (老段)5 小时前
从关系型数据库到时序数据库的思维转变
大数据·数据库·mysql·时序数据库·tdengine·涛思数据·非关系型数据库
老兵发新帖5 小时前
ubuntu网络管理功能分析
数据库·ubuntu·php