V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Newyorkcity
V2EX  ›  问与答

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

  •  
  •   Newyorkcity · 115 天前 via Android · 959 次点击
    这是一个创建于 115 天前的主题,其中的信息可能已经有所发展或是发生改变。
    两者底层不都是使用 B 树吗?理论上查询与插入应该时间复杂度上没差吧?看到网上说大量读过存储的场景使用 nyisam 更好,不太理解原因。

    谢谢解惑
    9 条回复    2020-09-25 12:50:39 +08:00
    chenzheyu
        1
    chenzheyu   115 天前
    都 innodb,到时候需求变了更忧伤。真有大量读缓存不是更适合。
    MeteorCat
        2
    MeteorCat   115 天前 via Android
    楼上说的对,读得再快还能快过 redis 缓存的数据吗?
    love
        3
    love   115 天前
    先问是不是,网上很多过期信息并不准确或只在特定情况下适用
    Newyorkcity
        4
    Newyorkcity   115 天前
    @chenzheyu
    @MeteorCat
    @love
    问题在于面试会被问啊 myisam 和 innodb 了解吗,说一下两者各自适合的场景和为什么。。。怎么说? myisam 在 innodb 出来之后就是没有价值了,它所有值得使用的场景都可以被 innodb 代替?
    sagaxu
        5
    sagaxu   115 天前 via Android   ❤️ 2
    @Newyorkcity 就一句话,没有任何场景用 myisam 更好
    reter
        6
    reter   115 天前   ❤️ 2
    https://dev.mysql.com/doc/refman/5.7/en/internal-locking.html

    myiasm 是表级锁,innodb 是行级锁

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

    多个读锁可共享,写锁要独占,因此 myiasm 适合读,innodb 适合写
    reter
        7
    reter   115 天前   ❤️ 1
    myiasm => myisam
    shc
        8
    shc   115 天前 via Android
    没记错的话 innodb 对长记录有限制。https://mariadb.com/kb/en/troubleshooting-row-size-too-large-errors-with-innodb/

    另外全文检索应该也最好 MyISAM/ARIA 吧。
    sadfQED2
        9
    sadfQED2   114 天前 via Android
    Myisam 是堆表,innodb 是索引表,innodb 合理使用索引可以不回表,那查询性能应该更好啊
    关于   ·   帮助文档   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4455 人在线   最高记录 5298   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 01:22 · PVG 09:22 · LAX 17:22 · JFK 20:22
    ♥ Do have faith in what you're doing.