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

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

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

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

    myiasm 是表级锁,innodb 是行级锁

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

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

    另外全文检索应该也最好 MyISAM/ARIA 吧。
    sadfQED2
        9
    sadfQED2  
       2020-09-25 12:50:39 +08:00 via Android
    Myisam 是堆表,innodb 是索引表,innodb 合理使用索引可以不回表,那查询性能应该更好啊
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1284 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 17:29 · PVG 01:29 · LAX 09:29 · JFK 12:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.