为什么对于读多写少的数据库,用 myisam 是比 innodb 更佳的原则?

2020-09-24 16:24:27 +08:00
 Newyorkcity
两者底层不都是使用 B 树吗?理论上查询与插入应该时间复杂度上没差吧?看到网上说大量读过存储的场景使用 nyisam 更好,不太理解原因。

谢谢解惑
2061 次点击
所在节点    问与答
9 条回复
chenzheyu
2020-09-24 19:28:27 +08:00
都 innodb,到时候需求变了更忧伤。真有大量读缓存不是更适合。
MeteorCat
2020-09-24 19:35:44 +08:00
楼上说的对,读得再快还能快过 redis 缓存的数据吗?
love
2020-09-24 19:45:39 +08:00
先问是不是,网上很多过期信息并不准确或只在特定情况下适用
Newyorkcity
2020-09-24 22:18:20 +08:00
@chenzheyu
@MeteorCat
@love
问题在于面试会被问啊 myisam 和 innodb 了解吗,说一下两者各自适合的场景和为什么。。。怎么说? myisam 在 innodb 出来之后就是没有价值了,它所有值得使用的场景都可以被 innodb 代替?
sagaxu
2020-09-24 22:32:59 +08:00
@Newyorkcity 就一句话,没有任何场景用 myisam 更好
reter
2020-09-24 23:02:24 +08:00
https://dev.mysql.com/doc/refman/5.7/en/internal-locking.html

myiasm 是表级锁,innodb 是行级锁

不管是写操作还是读操作,myiasm 只需要对表检查一次锁,开销小,范围大; innodb 读取写入每一行记录都要检查锁,开销大,范围小。

多个读锁可共享,写锁要独占,因此 myiasm 适合读,innodb 适合写
reter
2020-09-24 23:05:35 +08:00
myiasm => myisam
shc
2020-09-24 23:12:48 +08:00
没记错的话 innodb 对长记录有限制。https://mariadb.com/kb/en/troubleshooting-row-size-too-large-errors-with-innodb/

另外全文检索应该也最好 MyISAM/ARIA 吧。
sadfQED2
2020-09-25 12:50:39 +08:00
Myisam 是堆表,innodb 是索引表,innodb 合理使用索引可以不回表,那查询性能应该更好啊

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/710148

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX