V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
Newyorkcity
V2EX  ›  问与答

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

  •  
  •   Newyorkcity · Sep 24, 2020 via Android · 2495 views
    This topic created in 2041 days ago, the information mentioned may be changed or developed.
    两者底层不都是使用 B 树吗?理论上查询与插入应该时间复杂度上没差吧?看到网上说大量读过存储的场景使用 nyisam 更好,不太理解原因。

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

    myiasm 是表级锁,innodb 是行级锁

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

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

    另外全文检索应该也最好 MyISAM/ARIA 吧。
    sadfQED2
        9
    sadfQED2  
       Sep 25, 2020 via Android
    Myisam 是堆表,innodb 是索引表,innodb 合理使用索引可以不回表,那查询性能应该更好啊
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   4693 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 54ms · UTC 01:03 · PVG 09:03 · LAX 18:03 · JFK 21:03
    ♥ Do have faith in what you're doing.