Mysql的三类锁

来源:互联网 发布:现在淘宝客服工资多少 编辑:程序博客网 时间:2024/06/08 00:48
1、MySQL常用存储引擎的锁机制

  MyISAM和MEMORY采用表级锁(table-level locking)

  BDB采用页面锁(page-level locking)或表级锁,默认为页面锁

  InnoDB支持行级锁(row-level locking)和表级锁,默认为行级锁

  2、各种锁特点

  表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低

  行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高

  页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般

  3、各种锁的适用场景

  表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用

  行级锁则更适合于有大量按索引条件并发更新数据,同时又有并发查询的应用,如一些在线事务处理系统

0 0