zoukankan      html  css  js  c++  java
  • mysql的innodb和myisam的区别和应用场景

    1. 区别:

    (1)事务处理:

    MyISAM是非事务安全型的,而InnoDB是事务安全型的(支持事务处理等高级处理);

    (2)锁机制不同:

    MyISAM是表级锁,而InnoDB是行级锁;

    (3)select ,update ,insert ,delete 操作:

    MyISAM:如果执行大量的SELECT,MyISAM是更好的选择
    InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表

    (4)查询表的行数不同:

    MyISAM:select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含   where条件时,两种表的操作是一样的
    InnoDB : InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行
    (5)外键支持:
    mysiam表不支持外键,而InnoDB支持

    2. 为什么MyISAM会比Innodb 的查询速度快。

    INNODB在做SELECT的时候,要维护的东西比MYISAM引擎多很多;
    1)数据块,INNODB要缓存,MYISAM只缓存索引块,  这中间还有换进换出的减少; 
    2)innodb寻址要映射到块,再到行,MYISAM 记录的直接是文件的OFFSET,定位比INNODB要快
    3)INNODB还需要维护MVCC一致;虽然你的场景没有,但他还是需要去检查和维护
    MVCC ( Multi-Version Concurrency Control )多版本并发控制 
    3. 应用场景

    MyISAM适合:(1)做很多count 的计算;(2)插入不频繁,查询非常频繁;(3)没有事务。

    InnoDB适合:(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都相当的频繁,并且行锁定的机会比较大的情况。 

    myisam的引擎是表锁,读的时候会加读锁(共享锁)、只能读不能写,写的时候会加写锁(排他锁)、不能读也不能写。

    innodb是行锁,写的时候也会加(写锁)排他锁,读的时候不会加锁,如果要可以通过加悲观锁(共享锁和排他锁):

    共享锁: SELECT ... LOCK IN SHARE MODE;

    排他锁: SELECT ... FOR UPDATE;

    也可以通过乐观锁(加一个字段,更新完了加1);

    乐观锁常用的是版本控制或时间戳控制,

    先把版本查出来

    事务A:执行 此时版本为 1;执行完update ...set version=2 where version = 1;
    事务B:执行 此时版本为 1;执行完update ...set version=2 where version = 1;

    这时候事务B发现version=1已经不存在了,因为事务A首先执行完更新了数据库,把version字段设为了2,这样就会导致该事务提交失败,需要我们在程序中判断异常情况下如何继续操作。

    数据库操作可能出现的有脏读、幻读、不可重复读。mysql的隔离机制有可以读非未提交数据(可能出现脏读和幻读)、可以读已提交数据(脏读和不可重复读)建议使用,可以通过加悲观锁(排他锁和共享锁)、可重复读,串行方式。

  • 相关阅读:
    四、创建多线程、数据共享
    operator函数操作符
    三、线程传参
    二、线程创建、结束
    一、并发、进程、线程概念
    bagging和boosting的区别
    ID3,C4.5和CART三种决策树的区别
    7创建型模式之建造者模式
    6创建型模式之工厂模式与抽象工厂模式
    5创建型模式之简单工厂模式
  • 原文地址:https://www.cnblogs.com/3chi/p/8427744.html
Copyright © 2011-2022 走看看