在已经开启事务的前提下:

共享锁

A用户使用了共享锁,B用户可以使用共享锁或者不用锁能查询到数据,但是使用排他锁就会报错

A更新数据,但是会一直在等待,假如1s后B也更新数据,这时就会陷入死锁报错退出。然后A就能更新成功了

排他锁

A用户使用了排他锁,B用户就使用排他锁或者共享锁来获取数据,会一直等待中

A用户更新数据并提交事务,此时B用户用户获得锁成功并查得数据

InnoDb的锁的一些注意事项

1. 在不通过索引条件查询的时候,InnoDB确实使用的是表锁,而不是行锁

像我们平常通过id查询这个就是通过索引条件查询,因为一般来说id都会做为主键,主键会创建索引

如果通过user_name来查询这个就不是通过索引条件查询,除非你给user_name加一个索引就可以

2. 由于MySQL的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行的记录,但是如果是使用相同的索引键,是会出现锁冲突的。应用设计的时候要注意这一点。

3. 当表有多个索引的时候,不同的事务可以使用不同的索引锁定不同的行,另外,不论是使用主键索引、唯一索引或普通索引,InnoDB都会使用行锁来对数据加锁。

行锁与表锁的区别:

行锁顾名思义标识该条数据被锁,无法被获得锁的操作更新或者访问

表锁表示整个表都无法被未获得锁的操作更新或者访问

mysql锁机制分为表级锁和行级锁,

行级锁中的共享锁(select ... lock in share mode)与排他锁(select ...for update)进行分享交流

共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。

排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁的事务是可以对数据就行读取和修改。

对于共享锁大家可能很好理解,就是多个事务只能读数据不能改数据,对于排他锁大家的理解可能就有些差别,我当初就犯了一个错误,以为排他锁锁住一行数据后,其他事务就不能读取和修改该行数据,其实不是这样的。

排他锁指的是一个事务在一行数据加上排他锁后,其他事务不能再在其上加其他的锁。mysql InnoDB引擎默认的修改数据语句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类型,如果加排他锁可以使用select ...for update语句,加共享锁可以使用select ... lock in share mode语句。

所以加过排他锁的数据行在其他事务种是不能修改数据的,也不能通过for update和lock in share mode锁的方式查询数据,但可以直接通过select ...from...查询数据,因为普通查询没有任何锁机制。

说了这么多,咱们来看下以下简单的例子:

我们有如下测试数据

image

现在我们对id=1的数据行排他查询,这里会使用begin开启事务,而不会看见我关闭事务,这样做是用来测试,因为提交事务或回滚事务就会释放锁。

打开一个查询窗口

image

会查询到一条数据,现在打开另一个查询窗口,对同一数据分别使用排他查和共享锁查询两种方式查询

排他查

image

共享查

image

我们看到开了排他锁查询和共享锁查询都会处于阻塞状态,因为id=1的数据已经被加上了排他锁,此处阻塞是等待排他锁释放。

如果我们直接使用以下查询呢

image

我们看到是可以查询到数据的。

我们再看一下一个事务获取了共享锁,在其他查询中也只能加共享锁或不加锁。

image

image

image

我们看到是可以查询数据的,但加排他锁就查不到,因为排他锁与共享锁不能存在同一数据上。

最后我们验证下上面说的mysql InnoDb引擎中update,delete,insert语句自动加排他锁的问题,

image

image

此时共享查询处于阻塞,等待排它锁的释放,但是用普通查询能查到数据,因为没用上锁机制不与排他锁互斥,但查到的数据是修改数据之前的老数据。

image

然后我们提交数据,释放排他锁看下修改后的数据,此时可用排他查,共享查和普通查询, 因为事务提交后该行数据释放排他锁,下面就只显示普通查询,其他的同学们自己去验证。

image

image

可以看到结果与预期的一样。

mysql 行级排它锁_Mysql的行级锁 -- 共享锁和排他锁相关推荐

  1. mysql 共享锁和排他锁 意向锁 记录锁 Gap Locks Next-Key Locks 插入意向锁介绍

    文章目录 前言: 共享锁和排它锁 LOCK TABLES 和 UNLOCK TABLES 语句 意向锁 记录锁Record Locks 间隙锁 Gap Locks 下一键锁定 next-key 插入意 ...

  2. MySql: 表级锁、行级锁、共享锁、排他锁、乐观锁、悲观锁

    1.表级锁与行级锁 表级锁: table-level locking,锁住整个表. 开销小,加锁快. 不会死锁(一次性加载所需的所有表). 锁粒度大,发生锁冲突概率大,并发效率低. 适合查询. 行级锁 ...

  3. mysql innodb 排他锁_MySQL 针对 InnoDB 引擎锁的种类:行锁(共享锁和排他锁)和表锁(意向共享锁和意向排他锁)...

    InnoDB 锁快速到底 行锁:共享锁(S).排他锁(X) 表锁:意向共享锁(IS).意向排他锁(IX) 下面主要针对 MySQL 中行级锁中的共享锁(S)与排他锁(X)进行分析 共享锁又称为读锁,简 ...

  4. mysql锁机制——乐观锁、悲观锁;共享锁、排他锁、行表锁、间隔后码锁、MVCC 与 thinkphp的lock解析

    锁的引入 如果A有100元,同时对B.C转账,若处理是同时的,则此时同时读取A的余额为100元,在对两人转账后写回,A的余额不是0元而是50元.因此,为了防止这种现象的出现,要引入锁的概念,如只有在A ...

  5. mysql 排它锁_Mysql共享锁、排他锁、悲观锁、乐观锁

    一.相关名词 |--表级锁(锁定整个表) |--页级锁(锁定一页) |--行级锁(锁定一行) |--共享锁(S锁,MyISAM 叫做读锁) |--排他锁(X锁,MyISAM 叫做写锁) |--间隙锁( ...

  6. Mysql共享锁实例_mysql共享锁与排他锁用法实例分析

    本文实例讲述了mysql共享锁与排他锁用法.分享给大家供大家参考,具体如下: mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流. 共享锁又称 ...

  7. 共享锁、排他锁、互斥锁、悲观锁、乐观锁、行锁、表锁、页面锁、不可重复读、丢失修改、读脏数据...

    作者:T-Birds blog.csdn.net/weixin_36634753/article/details/90815755 共享锁(S锁): 又称为读锁,可以查看但无法修改和删除的一种数据锁. ...

  8. mysql排他锁_mysql共享锁与排他锁

    mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流. 共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能 ...

  9. mysql排他锁实例_mysql共享锁与排他锁用法实例分析

    本文实例讲述了mysql共享锁与排他锁用法.分享给大家供大家参考,具体如下: mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流. 共享锁又称 ...

最新文章

  1. linux shell rman删除归档_Oracle备份恢复必会--rman迁移,附实验步骤介绍
  2. 2017年9月2日普级组T2 跳格子
  3. Jena Fuseki安装完成后不能添加数据库
  4. Atom飞行手册翻译: 2.7 ~ 2.10
  5. python在线作业_南开大学20春学期《Python编程基础》在线作业参考答案
  6. icmp端口_pingtunnel搭建icmp隧道
  7. MySQL 性能优化--QueryCache的原理
  8. FISCO BCOS源码(5)基本概念
  9. ac1900 linksys 恢复_把变砖的Linksys-AC1900路由器救活
  10. python grasshopper_Grasshopper操作shp
  11. java ssm网上超市购物管理系统
  12. Coverity介绍以及典型缺陷说明
  13. C语言:for循环(for循环,while 循环:计算1加到100的值)
  14. Gitter+Sidecar制作聊天室
  15. 关于100层楼,扔两个鸡蛋,求摔碎鸡蛋的临界层的问题
  16. 用户盘云存储——百度网盘
  17. Beef-xss安装及使用
  18. BZOJ 3609: [Heoi2014]人人尽说江南好
  19. 利用matlab绘制系统开环幅频渐进特性曲线(附详细注释)
  20. win10系统空闲一段时间后鼠标键盘没反应,屏幕卡死

热门文章

  1. android计算器求余,我的小计算器快完成了,就差一个取余和幂的运算了,下午搞定它...
  2. 5G车联网技术对自动驾驶的赋能
  3. Java开发工具之社区版IDEA的安装使用
  4. Java基础-遍历数组
  5. 【Ubuntu】16.04服务器:驱动更新+cuda11+cudnn
  6. AI的图像描摹和扩展
  7. android 实现在照片上涂鸦
  8. nvidia-docker的配置及使用
  9. 游险理赔项目有哪些?
  10. 设置App桌面图标上显示的角标数字