码迷,mamicode.com
首页 > 数据库 > 详细

Mysql 锁机制

时间:2018-06-24 22:33:48      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:被锁   current   upd   span   nbsp   ssi   表名   其他   SQ   

表锁 Myisam引擎(表级)

读锁定时,不能写, 写锁定A表时,其他session不能读和写A表

  读锁session-1 只能查A表,不能查其他B表

              session-2 写阻塞,能查询所有表

  写锁session-1 能改A表, 不能查其他表

    session-2 不能查A表,更加不能写操作.

lock tables 表名 read|write; 

unlock 表名

 

行锁 InnerDB引擎(行级)

     无索引引发的表锁

     间隙锁的危害,使用范围检索数据,InnoDB会给符合条件的记录索引枷锁,对于键值范围内但并不存的记录,叫间隙锁

    危害:Query时,范围内的所有索引值被锁, 间隙值行记录会被阻塞

  

 分析行锁

 show status like ‘innodb_row_lock%‘;

技术分享图片

**_current_waits:当前正在等待锁定的数量 和

**_time 等待的总时长

**_time_avg 等待平均时长

**_time_max 等待最长的一次所花时间

**_waits: 系统启动后到现在的总共等待次数

 

如何锁定一行?

begin

select * from tables where *** for update;

commit;

 

 

页锁

Mysql 锁机制

标签:被锁   current   upd   span   nbsp   ssi   表名   其他   SQ   

原文地址:https://www.cnblogs.com/eason-d/p/9221831.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!