samdung 发表于 2018-10-4 09:22:50

mysql 的锁

  一、表级锁:
  MyISAM引擎,可以理解为锁整张表,可以同时读,不可以同时写。
  在锁定期间,其它进程无法对该表进行写操作,如果是写锁,则其它进程则不允许读。
  二、行级锁:
  InnoDB引擎,单独一行记录加锁,可以同时读,不可同时写。
  行级锁开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
  三、InnoDB行锁
  由于InnoDB预设是Row-Level Lock,所以只有[明确]的指定主键,MySQL才会执行Row lock,否则MySQL将会执行Table Lock
  例1:(明确指定主键,并且有此记录,Row Lock)

  SELECT * FROM products WHERE>
  SELECT * FROM products WHERE>  1
  2
  例2: (明确指定主键,若查无此记录,无lock)

  SELECT * FROM products WHERE>  1
  例3: (无主键,table lock)
  SELECT * FROM products WHERE name='Mouse' FOR UPDATE;
  1
  例4: (主键不明确,table lock)

  SELECT * FROM products WHERE>  1
  例5: (主键不明确,table lock)

  SELECT * FROM products WHERE>
页: [1]
查看完整版本: mysql 的锁