精华内容
下载资源
问答
  • 共享锁和排他锁

    2017-07-30 14:38:30
    共享锁和排他锁

    1.共享锁(Share Lock)

    共享锁又称读锁,是读取操作创建的锁。其他用户可以并发读取数据,但任何事务都不能对数据进行修改(除非获取数据上的排他锁),直到已释放所有共享锁。
    如果事务T对数据A加上共享锁后,则其他事务只能对A再加共享锁,不能加排他锁。获准共享锁的事务只能读数据,不能修改数据。

    用法

    SELECT ... LOCK IN SHARE MODE;

    在查询语句后面增加LOCK IN SHARE MODE,Mysql会对查询结果中的每行都加共享锁,当没有其他线程对查询结果集中的任何一行使用排他锁时,可以成功申请共享锁,否则会被阻塞。其他线程也可以读取使用了共享锁的表,而且这些线程读取的是同一个版本的数据。

    2.排他锁(Exclusive Lock)

    排他锁又称写锁,如果事务T对数据A加上排他锁后,则其他事务不能再对A加任任何类型的封锁。获准排他锁的事务既能读数据,又能修改数据。

    用法

    SELECT ... FOR UPDATE;

    在查询语句后面增加FOR UPDATE,Mysql会对查询结果中的每行都加排他锁,当没有其他线程对查询结果集中的任何一行使用排他锁时,可以成功申请排他锁,否则会被阻塞。

    展开全文
  • MySQL 共享锁和排他锁

    2020-09-27 09:33:12
    一、共享锁和排他锁 共享锁又称为读锁,简称D锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。 排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所...

    一、共享锁和排他锁

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

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

    自己的理解


    现在一个简单的例子:

    这个表进行操作
    在这里插入图片描述

    对id = 1 进行排他锁操作,使用begin开启事务。提交事务或回滚事务就会释放锁。

    begin; -- 开启事务
    
    select * from actor where id = 1 for update; -- 进行id = 1排他锁 
    

    在这里插入图片描述

    可以查询到数据,再打开另外一个查询窗口。对同一数据进行排他锁和共享锁操作

    select * from actor where id = 1 for update; -- 排他查
    
    select * from actor where id = 1 lock in share mode; -- 共享查
    
    -- 开了排他锁查询和共享锁查询都会处于阻塞状态,因为id=1的数据已经被加上了排他锁,此处阻塞是等待排他锁释放。
    
    select * from actor where id = 1 --这个可以查询到数据
    

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

    begin;
    
    select * from actor where id = 1 lock in share mode
    
    select * from actor where id = 1; 
    select * from actor where id = 1 lock in share mode;
    -- 可以查詢到數據
    
    select * from actor where id = 1 for update;
    -- 查詢不到數據 ,因为排他锁与共享锁不能存在同一数据上。
    

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

    begin;
    
    update actor set name = 'aa' where id = 1;
    
    select * from actor where id = 1 lock in share mode;
     -- 此时共享查询处于阻塞,等待排它锁的释放,但是用普通查询能查到数据,因为没用上锁机制不与排他锁互斥,但查到的数据是修改数据之前的老数据。
    
    select * from actor where id = 1; -- 可查到數據
    
    然后我们提交数据,释放排他锁看下修改后的数据,此时可用排他查,共享查和普通查询, 因为事务提交后该行数据释放排他锁,下面就只显示普通查询。
    

    二、for update

    select … for update 语句是我们经常使用手工加锁语句。会对数据库中的表或某些行数据进行锁表,在mysql中,如果查询条件带有主键,会锁行数据,如果没有,会锁表。

    1. FOR UPDATE仅适用于InnoDB,且必须在事务处理模块(BEGIN/COMMIT)中才能生效。
    2. 要测试锁定的状况,可以利用MySQL的Command Mode(命令模式) ,开两个视窗来做测试。
    3. Myisam 只支持表级锁,InnerDB支持行级锁 添加了(行级锁/表级锁)锁的数据不能被其它事务再锁定,也不被其它事务修改。是表级锁时,不管是否查询到记录,都会锁定表。

    什么时候需要使用for update?
    借助for update语句,我们可以在应用程序的层面手工实现数据加锁保护操作。就是那些需要业务层面数据独占时,可以考虑使用for update。

    场景上,比如火车票订票,在屏幕上显示有票,而真正进行出票时,需要重新确定一下这个数据没有被其他客户端修改。所以,在这个确认过程中,可以使用for update。

    for update 悲观锁
    悲观锁:总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它解锁。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。就像for update,再比如Java里面的同步原语synchronized关键字的实现也是悲观锁。

    乐观锁:顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库提供的类似于write_condition机制,其实都是提供的乐观锁。

    展开全文
  • 分享给大家供大家参考,具体如下:mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁排他锁进行分享交流。共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据...

    本文实例讲述了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...查询数据,因为普通查询没有任何锁机制。

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

    我们有如下测试数据

    2019091512002115.png

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

    打开一个查询窗口

    2019091512002116.png

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

    排他查

    2019091512002117.png

    共享查

    2019091512002118.png

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

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

    2019091512002119.png

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

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

    2019091512002120.png

    2019091512002121.png

    2019091512002122.png

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

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

    2019091512002123.png

    2019091512002124.png

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

    2019091512002125.png

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

    2019091512002126.png

    2019091512002127.png

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

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

    更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL数据库锁相关技巧汇总》、《MySQL存储过程技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》及《MySQL事务操作技巧汇总》

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

    本文标题: mysql共享锁与排他锁用法实例分析

    本文地址: http://www.cppcns.com/shujuku/mysql/274072.html

    展开全文
  • mysql共享锁和排他锁

    2020-02-24 10:41:01
    mysql锁机制分为表级锁和行级锁,本文就和大家...排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁...

    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中共享锁与排他锁的个人理解,有不正确的地方还希望各位指正。

    <a href="https://www.cnblogs.com/boblogsbo/p/5531630.html" class="p_n_p_prefix">« </a> 上一篇:    <a href="https://www.cnblogs.com/boblogsbo/p/5531630.html" title="发布于 2016-05-26 16:31">springmvc注解式事务手动回滚</a>
    <br>
    <a href="https://www.cnblogs.com/boblogsbo/p/5718159.html" class="p_n_p_prefix">» </a> 下一篇:    <a href="https://www.cnblogs.com/boblogsbo/p/5718159.html" title="发布于 2016-07-29 14:03">ActiveMQ消息队列用法</a>
    
    展开全文
  • ********共享锁****也叫读锁,简称S锁,原理:一个事务获取了一个数据行的共享锁,其他事务能获得该行对应的共享锁,但不能获得排他锁,即一个事务在读取一个数据行的时候,其他事务也可以读,但不能对该数据行进行...
  • mysql锁机制分为表级锁和行级...排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁...
  • 排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁的事务是可以对数据就行读取和...
  • mysql锁机制分为表级锁和行级锁,本文...排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获...
  • mysql锁机制分为表级锁和行级...排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁...
  • mysql锁机制分为表级锁和行级...排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他所并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁,包括共享锁和排他锁,但是获取排他锁...
  • JAVA共享锁和排他锁总结

    千次阅读 2020-05-11 17:32:16
    共享锁和排他锁总结1.ReentrantReadWriteLock2.锁申请和释放策略3.插队策略4.升降级策略5.使用场合总结 1.ReentrantReadWriteLock 实现了ReadWriteLock接口,最主要的有两个方法:readLock()和writeLock()用来获取读...
  • 数据库中的共享锁和排他锁

    千次阅读 2018-07-27 14:26:38
    行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁和排他锁的概念、使用方式及注意事项。 共享锁(Share Lock) 共享锁又称读锁,是读取操作创建的锁。其他用户可以并发读取数据,但任何事务都不能对数据进行...
  • 行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁和排他锁的概念、使用方式及注意事项。共享锁(Share Lock)共享锁又称读锁,是读取操作创建的锁。其他用户可以并发读取数据,但任何事务都不能对数据进行修改...
  • 详述 MySQL 中的共享锁和排他锁

    千次阅读 2017-04-10 11:03:18
    行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁和排他锁的概念、使用方式及注意事项。共享锁(Share Lock)共享锁又称读锁,是读取操作创建的锁。其他用户可以并发读取数据,但任何事务都不能对数据进行修改...
  • 周末,我正在看电视剧,是那个小说改编的《斗破苍穹》,看的正嗨的时候,... 共享锁,又称为读锁,获得共享锁之后,可以查看但无法修改删除数据。排他锁,又称为写锁、独占锁。获准排他锁后,既能读数据,又能修改...
  • 行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁及排他锁的概念、使用方式及注意事项等。 共享锁(Share Lock) 共享锁又称读锁,是读取操作创建的锁。其他用户可以并发读取数据,但任何事务都不能对数据...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 2,178
精华内容 871
关键字:

共享锁和排他锁