Mysql数据库InnoDB引擎的锁

  • 概述

      Mysql常用引擎有MYISAM和InnoDB,而InnoDB是mysql默认的引擎。MYISAM不支持行锁,而InnoDB支持行锁和表锁。

  • 行锁:
  1. 共享锁(S):允许一个事务去读一行,阻止其他事务获得相同的数据集的排他锁(读的时候,其他可以读,但是不能写)。
  2. 排他锁(X):允许获得排他锁的事务更新数据,但是阻止其他事务获得相同数据集的共享锁和排他锁(写的时候,其他事物不能读和写)。
  • sql语句中锁使用

    对于UPDATE、DELETE和INSERT语句,InnoDB会自动给涉及数据集加排他锁;

    对于普通SELECT语句,InnoDB不会加任意锁,当前读(特殊的读操作,需手动加上共享锁)。

  1. SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE;  #共享锁
  2. SELECT * FROM table_name WHERE ... FOR UPDATE;  #排他锁
  3. insert into table values (…);    #排他锁
  4. update table set ? where ?;    #排他锁
  5. delete from table where ?;    #排他锁
  • 表级锁相关
  1. 为了允许行锁和表锁共存,实现多粒度锁机制,InnoDB还有两种内部使用的意向锁(意向共享锁(IS)和意向排他锁(IX))。这两种意向锁都是表锁。意向锁是InnoDB自动加的,不需要用户干预。
  2. mysql的行锁是通过索引加载的,即行锁是加在索引响应的行上的,要是对应的SQL语句没有走索引,则会全表扫描,行锁则无法实现,取而代之的是表锁。

你可能感兴趣的:(开发总结,开发总结)