本文实例讲述了mysql共享锁与排他锁用法。分享给大家供大家参考,具体如下:

mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流。

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

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

对于共享锁大家可能很好理解,就是多个事务只能读数据不能改数据,对于排他锁大家的理解可能就有些差别,我当初就犯了一个错误,以为排他锁锁住一行 数据后,其他事务就不能读取和修改该行数据,其实不是这样的。排他锁指的是一个事务在一行数据加上排他锁后,其他事务不能再在其上加其他的锁。mysql InnoDB引擎默认的修改数据语句,update,delete,insert都会自动给涉及到的数据加上排他锁,select语句默认不会加任何锁类 型,如果加排他锁可以使用select ...for update语句,加共享锁可以使用select ... lock in share mode语句。所以加过排他锁的数据行在其他事务种是不能修改数据的,也不能通过for update和lock in share mode锁的方式查询数据,但可以直接通过select ...from...查询数据,因为普通查询没有任何锁机制。

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

我们有如下测试数据

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

打开一个查询窗口

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

排他查

共享查

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

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

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

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

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

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

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

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

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

以上为我对mysql中共享锁与排他锁的个人理解,有不正确的地方还希望各位指正。

希望本文所述对大家MySQL数据库计有所帮助。

Mysql共享锁实例_mysql共享锁与排他锁用法实例分析相关推荐

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

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

  2. mysql transaction用法,mysql的事务,隔离级别和锁用法实例分析

    本文实例讲述了mysql的事务,隔离级别和锁用法.分享给大家供大家参考,具体如下: 事务就是一组一起成功或一起失败的sql语句.事务还应该具备,原子性,一致性,隔离性和持久性. 一.事务的基本要素 ( ...

  3. mysql 自定义函数实例_mysql自定义函数原理与用法实例分析

    本文实例讲述了mysql自定义函数原理与用法.分享给大家供大家参考,具体如下: 本文内容: 什么是函数 函数的创建 函数的调用 函数的查看 函数的修改 函数的删除 首发日期:2018-04-18 什么 ...

  4. mysql 表死锁_MySQL Innodb表导致死锁日志情况分析与归纳

    案例描述在定时脚本运行过程中,发现当备份表格的sql语句与删除该表部分数据的sql语句同时运行时,mysql会检测出死锁,并打印出日志. 两个sql语句如下:(1)insert into backup ...

  5. mysql读锁(共享锁)与写锁(排他锁)

    概述 读锁又称为共享锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改. 写锁又称为排他锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个 ...

  6. 数据库共享锁(读锁)和排他锁(写锁)

    为了保持数据的一致性,数据库提供了事务.但是,这只能解决单个会话的问题,并不能解决并发操作下数据的一致性. 并发操作下,数据会出现以下问题: 1.修改丢失 事务A与事务B从数据库中读入同一数据并修改, ...

  7. mysql5.7单机多实例_Mysql 5.7.21单机多实例安装

    下载MySQL 5.7 二制包 [root@MySQL ~]# wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.21-linu ...

  8. mysql中join on_Mysql inner join on的用法实例(必看)

    语法规则 SELECT column_name(s) FROM table_name1 INNER JOIN table_name2 ON table_name1.column_name=table_ ...

  9. python回调函数实例详解_Python回调函数用法实例详解

    本文实例讲述了Python回调函数用法.分享给大家供大家参考.具体分析如下: 一.百度百科上对回调函数的解释: 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函 ...

最新文章

  1. 深度学习三巨头共同发文,聊聊深度学习的过去、现在与未来
  2. “上拉电阻与下拉电阻”通俗解读
  3. 互联网公司面试必问的Redis题目
  4. (转)Javascript面向对象编程(二):构造函数的继承
  5. ZOJ 3471 压缩状态DP
  6. 腾讯首个软硬件全自研的机器狗 Max 来了!
  7. Linux的环境中如何生成srw-rw---- 的文件权限?
  8. java web不用框架_初学javaweb,远离各自框架
  9. Informatica的IDP理念:让业务部门成为真正数据受益者
  10. DIY智能车赛优胜奖开源作品——手机遥控麦克纳姆轮小车(1)
  11. AFDX(ARINC664)的网络协议——IP层
  12. 从入门到变现|全面解析视频号运营规则,看完少走3天弯路!
  13. 设置wps如何自动生成论文目录结构
  14. 拨号服务器可以端口映射吗,常见的几种ADSL 路由器端口映射设置方法
  15. Win10系统下安装CAD2006与CASS
  16. 【Java】接口.案例.打印机
  17. 基于微信小程序云开发(校园许愿墙app)2.0稳定版,以发布上线
  18. 手机储存卡数据如何恢复
  19. SSD固态硬盘和HDD机械硬盘的区别
  20. redis关于set的常用命令

热门文章

  1. 【深度学习篇】--神经网络中的调优二,防止过拟合
  2. 上接稳扎稳打Silverlight(20) - 2.0通信之WebClient, 以字符串的形式上传/下载数据
  3. MOSS SDK学习笔记系列文章
  4. 【Python】Numpy扩充数组函数之repeat和tile用法
  5. 数据库——修改表信息(转)
  6. jquery判断页面是否滑动到最底部
  7. 自定义标签 tag AttachTag 实现附件jsp方便的显示和下载
  8. windows codeblocks clang 3.7.0
  9. secureCRT自动断开的解决方法
  10. setTimeout和setInterval实现定时器的区别