首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql 加共享锁

基础概念

MySQL中的共享锁(Shared Locks),也称为读锁(Read Locks),是一种用于控制多个事务对同一数据行并发访问的机制。当一个事务获取了共享锁后,其他事务可以继续获取共享锁(进行读操作),但不能获取排他锁(进行写操作),直到持有共享锁的事务释放锁。

相关优势

  1. 并发性:允许多个事务同时读取同一数据行,提高了系统的并发性能。
  2. 数据一致性:通过锁机制,确保在读取数据时不会被其他事务修改,从而保证了数据的一致性。

类型

MySQL中的共享锁主要涉及以下两种锁:

  1. 共享锁(S锁):允许多个事务同时读取同一数据行,但阻止其他事务获取排他锁。
  2. 排他锁(X锁):阻止其他事务获取共享锁或排他锁,用于写操作。

应用场景

共享锁主要应用于以下场景:

  1. 多读少写:当系统中读取操作远多于写入操作时,使用共享锁可以提高并发性能。
  2. 数据一致性要求较高:在需要确保数据在读取过程中不被修改的场景中,使用共享锁可以保证数据的一致性。

遇到的问题及解决方法

问题:为什么在某些情况下,即使使用了共享锁,仍然会出现数据不一致的情况?

原因

  1. 锁粒度问题:如果锁的粒度过大(例如对整个表加锁),会导致并发性能下降;如果锁的粒度过小(例如只对部分行加锁),可能会导致数据不一致。
  2. 锁升级问题:在某些情况下,MySQL可能会自动将共享锁升级为排他锁,从而导致其他事务无法读取数据。

解决方法

  1. 优化锁粒度:根据实际需求,合理设置锁的粒度,避免锁粒度过大或过小。
  2. 使用事务隔离级别:通过设置合适的事务隔离级别(如REPEATABLE READSERIALIZABLE),可以减少锁升级的可能性。
  3. 使用乐观锁或悲观锁:根据具体业务场景,选择合适的锁策略,如乐观锁(通过版本号控制并发)或悲观锁(通过显式加锁控制并发)。

示例代码

以下是一个使用共享锁的示例代码:

代码语言:txt
复制
START TRANSACTION;
SELECT * FROM table_name WHERE id = 1 LOCK IN SHARE MODE;
-- 执行其他读操作
COMMIT;

在这个示例中,LOCK IN SHARE MODE关键字用于获取共享锁,确保在事务提交之前,其他事务无法修改该行数据。

参考链接

MySQL共享锁与排他锁详解

希望以上信息能够帮助您更好地理解MySQL中的共享锁及其相关应用。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL 意向共享锁、意向排他锁、死锁

专栏持续更新中:MySQL详解 一、InnoDB表级锁 我们知道,InnoDB是支持行锁,但不是每次都获取行锁,如果不使用索引的,那还是获取的表锁。...除了挨个检查,没有更好的办法,这就导致效率低下的问题 我们这里学习的意向共享锁和意向排他锁就是用来解决,由于需要加表锁而去挨个遍历数据,确定是否有某些数据被加了行锁,而导致的效率低下问题。...作用就是快速判断表里是否有记录被加锁 二、意向共享锁和意向排他锁(表锁而非行锁) 意向锁的作用:为了可以更快速的获取表锁 意向共享锁(IS锁):事务在给一行记录加共享锁前,必须先取得该表的IS锁 意向排他锁...分析事务1获取行X锁和事务2获取表S锁: 首先事务1需要给表的第10行数据加X锁,于是InnoDB存储引擎自动给整张表加上了IX锁。...当事务2再想获取整张表的S锁时,看到这张表已经有别的事务获取了IX锁了,就说明这张表肯定有某些数据被加上了X锁,这就导致事务2不能给整张表加S锁了。

1K40
  • MySQL表锁、行锁、排它锁和共享锁

    专栏持续更新中:MySQL详解 事务隔离级别的实现原理:简单来说就是各种锁机制和MVCC多版本并发控制 我们学习知识的时候,需要了解知识点出现的原因,什么情况下能用到这个知识 我们说到事务,就得说到事务的...开销小(因为不用去找表的某一行的记录进行加锁,要修改这张表,直接申请加这张表的锁),加锁快,不会出现死锁;锁粒度大,发生锁冲突的概率高,并发度低 行级锁:对某行记录加锁。...此时会放弃使用索引,因此也不会使用行锁,而是使用表锁,比如对一些很小的表,MySQL就不会去使用索引 三、排它锁(Exclusive)和共享锁(Shared) 排它锁,又称为X锁,写锁 共享锁,又称为...操作,加锁期间其它事务能对A加S锁但不能加 X 锁 一个事务对数据对象A加了 X 锁,就可以对A进行读取和更新,加锁期间其它事务不能对A加任何锁 显式加锁:select … lock in share...表级锁还是行级锁说的是锁的粒度,共享锁和排他锁说的是锁的性质,不管是表锁还是行锁,都有共享锁和排他锁的区分

    29340

    Mysql锁共享锁排它锁 (1)—mysql进阶(六十八)

    锁定读(locking read) 共享锁和独占锁 前面说过并发的情况下 读-读 不会有问题,不过对于 写-写,读-写,写-读这些情况可能引引起一些问题,需要使用mvcc或者加锁的方式来解决。...在使用加锁的方式解决问题时候,mysql设计了两个锁的分类: 共享锁:shared locks,简称s锁。事务读取一条记录时候,必须先获取该记录的锁。...Insert: 一般来说,新插入的数据不需要加锁,mysql提供一种隐式锁来保护这条新数据在事务提交之前,不被其他事物来访问。...其实一个事务也可以在表级别进行加锁,自然称为表级锁或者表锁,对表加锁我们可以说这个锁的颗粒度比较粗,给表加锁分为共享锁和排它锁: 1、给表加s锁: 如果一个事务给表加s锁,那么, 别的事务可以继续获得该表的...这时候我们怎么知道整栋楼里有没有教室上锁呢,难道一次遍历,那太慢了,于是innoDB有个意向锁,Intention locks: 意向共享锁:intention shared locks,is锁,当事务给某行记录上

    65710

    MySQL中的锁(表锁、行锁,共享锁,排它锁,间隙锁)

    其中,除了第一条语句,对读取记录加S锁 (共享锁)外,其他的操作,都加的是X锁 (排它锁)。 select * from table where ?...update语句,加共享锁可以使用select … lock in share mode语句。...意向共享锁(IS):事务打算给数据行共享锁,事务在给一个数据行加共享锁前必须先取得该表的IS锁。 意向排他锁(IX):事务打算给数据行加排他锁,事务在给一个数据行加排他锁前必须先取得该表的IX锁。...事务可以通过以下语句显式给记录集加共享锁或排他锁: 共享锁(S):mysql SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE。...(2)由于MySQL的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行的记录,但是如果是使用相同的索引键,是会出现锁冲突的。应用设计的时候要注意这一点。

    2.5K30

    MySQL:表级锁、行级锁、共享锁、排他锁、乐观锁、悲观锁

    并不是直接丢记录行加锁,而是对行对应的索引加锁: 如果sql 语句操作了主键索引,Mysql 就会锁定这条主键索引。...如果sql语句操作了非主键索引,MySQL会先锁定该非主键索引,再锁定相关的主键索引。 在InnoDB中,如果SQL语句不涉及索引,则会通过隐藏的聚簇索引来对记录加锁。...InnoDB引擎支持表级锁和行级锁,默认为行级锁。 共享锁与排他锁 共享锁: 有称之为S锁、读锁。...当前线程对共享资源加共享锁,其他线程可以读取此资源、可以继续追加共享锁,但是不能修改此资源、不能追加排他锁。...当前线程对共享资源加排他锁,其他线程不允许读取此资源,不允许追加共享锁,不允许修改此资源,不允许追加排他锁。

    1.1K20

    MySQL 核心模块揭秘 | 20 期 | 怎么加表锁?

    本文基于 MySQL 8.0.32 源码,存储引擎为 InnoDB。 正文 1. 是否已经加锁? 一个事务,在执行过程中,可能多次操作同一个表。...以事务 T1 读取某个表的多条记录,并且需要加行级别的共享锁为例。 每次加行级别的共享锁之前,都会触发操作:给记录所在的表加表级别的意向共享锁。...每次加表级别的意向共享锁之前,如果 InnoDB 判断事务 T1 已经给这个表加了表级别的意向共享锁、意向排他锁、共享锁、排他锁中的一个,就不会执行本次加表锁操作了。.... // 锁模式计数加 1 ++table->count_by_mode[type_mode & LOCK_MODE_MASK]; ... } 表级别的排他锁和意向共享锁不兼容,表级别的共享锁...本次要加的表锁,即不是意向共享锁,也不是意向排他锁。 遍历 locks 链表的过程中,每次取出一个表锁结构,我们称之为 locks 表锁结构。

    8510

    独占锁(写锁)共享锁(读锁)互斥锁

    独占锁:指该锁一次只能被一个线程所持有。对ReentrantLock和Synchronized而言都是独占锁 共享锁:指该锁可被多个线程所持有。...对ReentrantReadWriteLock其读锁是共享锁,其写锁是独占锁。 读锁的共享锁可保证并发读是非常高效的,读写,写读,写写的过程是互斥的。...使用方法 声明一个读写锁 如果需要独占锁则加从可重入读写锁里得到写锁 写锁demo 如果需要共享锁则加从可重入读写锁里得到读锁 读锁demo ReentrantReadWriteLock实现原理简单分析...ReentrantReadWriteLock 的核心是由一个基于AQS的同步器 Sync 构成,然后由其扩展出 ReadLock (共享锁), WriteLock (排它锁)所组成。...Sync是如何同时表示读锁与写锁?

    1.4K30

    并发锁(二):共享锁和独占锁

    首先,我们要分清楚,锁有2种,共享锁,以及独占锁 共享锁 共享锁用于某个文件不会被写,或者不会被更新(也就是只读)的情况,加了共享锁的文件,只能再加共享锁,而不能加独占锁 例如: $file = fopen...同样,如果在上了共享锁的情况,增加独占锁,则该进程会阻塞,直到共享锁释放: 锁还是共享锁,否则数据还是会出现问题 例如: 当加好共享锁之后,运行这段代码: 共享锁也会出现一样的情况(不做测试) 注意事项 独占锁加上之后,虽然其他进程无法加共享锁以及独占锁,但是可以直接写入文件,同样会造成数据污染,所以注意,当你确定某个文件确定需要加锁时,关于操作这个文件的代码...,都需要增加锁,不管是独占锁还是共享锁,否则数据还是会出现问题 <?

    1.7K21

    AQS之共享锁

    先简单总结一个AQS的特性 双向链表,有头节点和尾节点,FIFO,尾进头出,每个线程会被封装成一个Node 状态state,被volatile关键字修饰 独占模式下:获取锁后state值加1,释放锁后...state值减1,通过CAS原子操作加减,state==0表可以获取锁,state>1代表锁重入 共享模式下,state>0代表可以获取锁,同步器初始化的时候,会给sate设置一个初始化,这个值代表同时允许多少个线程获取锁...共享模式下, tryAcquireShared返回值的特点是:小于0代表获取锁失败;等于0代表本次获取锁成功,但随后的获取将返回失败,也就是此刻这是共享模式下的最后一把锁,除非接下来有人释放锁,否则你获取不了...tryAcquireShared返回值特点:小于0代表获取锁失败;等于0代表本次获取锁成功,但随后的获取将返回失败,也就是此刻这是共享模式下的最后一把锁,除非接下来有人释放锁,否则你获取不了;大于0代表本次获取锁成...,共享锁代表在同一时刻可以有多个线程获取锁,具体有几个线程由用户自己决定;而独占锁代表同一个时刻只能由一个线程获取锁 即然同一时刻可以有多个线程获取锁,那在释放锁的时候,怎么尽快的唤醒其它阻塞的节点呢?

    69410

    linux读写锁_共享内存读写锁

    读写锁其实还是一种锁,是给一段临界区代码加锁,但是此加锁是在进行写操作的时候才会互斥,而在进行读的时候是可以共享的进行访问临界区的 ps:读写锁本质上是一种自旋锁 二、为什么需要读写锁?...而读的机会却是非常多的,此公共数据的操作基本都是读,如果每次操作都给此段代码加锁,太浪费时间了而且也很浪费资源,降低程序的效率,因为读操作不会修改数据,只是做一些查询,所以在读的时候不用给此段代码加锁,可以共享的访问...,只有涉及到写的时候,互斥的访问就好了 三、读写锁的行为 读写之间是互斥的—–>读的时候写阻塞,写的时候读阻塞,而且读和写在竞争锁的时候,写会优先得到锁 四、自旋锁&挂起等待是锁?...1.自旋锁 自旋锁是在发生获取不到锁的时候,会直接等待,不会被CPU直接调度走,而是会一直等到获取到锁,因为此锁是一直的在等待,所以不会有调度的开销,故此锁的效率比挂起等待锁的效率高,但是此锁会因不停的查看锁的释放情况...(3)加锁和解锁 在进行读操作的时候加的锁: pthread_rwlock_rdlock(pthread_rwlock_t* rwlock); 在进行写操作的时候加的锁: pthread_rwlock_wrlock

    6.2K11

    ✅什么是排他锁、共享锁、意向锁

    LOCK IN SHARE MODE;在查询语句后增加LOCK IN SHARE MODE,MySQL会对查询结果中的每一行都加上共享锁。...如果事务T对数据A加上排他锁,则其他事务无法对A加任何类型的锁。获得排他锁的事务既能读取数据,又能修改数据。SELECT ......意向锁在MySQL的InnoDB引擎中,支持多种锁级别,其中包括行级锁和表级锁。当多个事务需要访问同一共享资源时,如果每个事务都直接请求获取锁,可能会发生相互阻塞的情况,甚至可能导致死锁的产生。...因此,MySQL引入了意向锁机制。意向锁是数据库管理系统中用于实现锁协议的一种机制,旨在处理不同锁粒度(如行锁和表锁)之间的并发性问题。...意向锁并非由用户直接请求,而是由MySQL管理的。当一个事务请求获取行级锁或表级锁时,MySQL会自动获取相应表的意向锁。

    53911

    MySQL中的表锁行锁共享锁很难吗?看了本文就清楚了哦

    MySQL数据库中的锁还是非常重要的,本文重点给大家详细的来介绍下MySQL数据中的各种锁。...查询操作(SELECT),会自动给涉及的所有表加读锁,更新操作(UPDATE、DELETE、INSERT),会自动给涉及的表加写锁。...表示事务准备给数据行加入共享锁,也就是一个数据行加共享锁前必须先取得该表的IS锁 意向排它锁(Intention Exclusive Lock,简称IX锁)表示事务准备给数据行加入排它锁,说明事务在一个数据行加排它锁前必须先获得该表的...为什么需要表级别的意向锁?   假设没有意向锁,我们加表锁的时候,需要去扫描全表是否有存在锁,数据量过大的时候,会导致加锁效率很低。...2.MySQL中锁的本质   在MySQL数据库中,锁的本质就是对索引打上标记,如果当前表没有索引,则直接找到sequence/rownum这样的默认表序列,完成锁表。

    72430

    Java的独占锁和共享锁

    共享锁 在Java中,共享锁(Shared Lock)是一种允许多个线程同时读取资源,但在写入资源时只允许一个线程独占的锁。...Java的java.util.concurrent.locks包中的ReentrantReadWriteLock类就是一种实现了共享锁和独占锁(排他锁)机制的读写锁。...在这个锁中,读锁是共享的,写锁是独占的。...在公平模式下,等待时间最长的线程将优先获得锁;而在非公平模式下,锁的分配不保证任何特定的顺序,新到来的线程可能立即获得锁。 要注意的是,尽管读锁是共享的,但写锁是独占的,并且写锁具有更高的优先级。...使用共享锁可以显著提高读取密集型应用的性能,因为它允许多个读取线程并发执行,而写入密集型应用可能会因为写锁的竞争而受到限制。

    29410

    利用LockSupport实现互斥锁和共享锁

    LockSupport是一个非常底层的API,我们利用其可以做很多事情,本文将利用LockSupport实现互斥锁和共享锁。...Lock有可重入的语义,一个线程拥有锁之后再次调用lock应该完全没有任何问题,所以锁的实现中需要维护一个已经获取锁的线程队列; Lock未成功需要阻塞当前线程,所以需要底层阻塞原语(LockSupport...)等的支持,并且在有线程释放锁之后需要唤起阻塞线程进行锁的竞争,所以需要维护等待锁的线程队列 Lock需要维护当前锁的状态(是否可以被获取等) 互斥锁 public class MutexLock implements...AtomicInteger,利用了CAS来维持锁的状态 共享锁 public class ShareLock implements Lock { private volatile Set<Thread...don't own this lock."); } state.getAndIncrement(); } } 总结 以上利用了LockSupport来实现了互斥锁和共享锁

    1K20

    MySQL锁、加锁机制(超详细)—— 锁分类、全局锁、共享锁、排他锁;表锁、元数据锁、意向锁;行锁、间隙锁、临键锁;乐观锁、悲观锁

    文章目录一、概述1.1 MySQL锁的由来1.2 锁定义1.3 锁分类二、共享锁与排他锁2.1 共享锁(S锁)2.2 排他锁(X锁)2.3 MySQL锁的释放三、全局锁3.1 介绍 3.2 语法 3.3...,因此先尝试执行,失败时再获取锁悲观锁:每次执行前都认为自己无法成功,因此会先获取锁,然后再执行放眼望下来,是不是看着还蛮多的,但总归说来说去其实就共享锁、排他锁两种,只是加的方式不同、加的地方不同,因此就演化出了这么多锁的称呼...是因为读操作默认加共享锁吗?并不是,因为你尝试加共享锁读这条数据时依旧会被排斥。...可以明显看到,第二个事务中尝试通过加共享锁的方式读取这条数据,依旧会陷入阻塞状态,那前面究竟是因为啥原因才导致的能读到数据呢?...MDL加锁过程是系统自动控制,无需显式使用,在访问一张表的时候会自动加上,当对一张表进行增删改查的时候,加MDL读锁(共享);当对表结构进行变更操作的时候,加MDL写锁(排他)。

    12.1K810

    【MySQL-25】万字总结<锁>——(全局锁&行级锁&表级锁)【共享锁,排他锁】【间隙锁,临键锁】【表锁,元数据锁,意向锁】

    前言 大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎!...,共享锁与排他锁互斥) 【2】情况2 不通过索引条件检索数据(InnoDB的行锁是针对于索引加的锁),那么InnoDB将对表中的所有记录加锁,此时 就会升级为表锁 演示: 有这么一张表,为主键索引...B: 我们想加一个表锁,我们先看有无意向锁,再看所要加的表锁与原来的意向锁是否兼容(读/写锁) ,不兼容则进入阻塞状态,直到线程A提交 2.意向锁的相关语法(意向共享锁&意向排他锁)(包含语法和演示)...schema.data locks; 演示: - 注:TABLE 为表锁 RECORD为行锁 如何确定加共享锁是意向锁呢?...输入查看代码 我们可以看到lock_mode下面表锁对应的是IS,说明加的共享锁是意向共享锁 我们知道,意向共享锁(IS): 与表锁共享锁(read)兼容 , 与表锁排它锁(write)互斥 也就意味着此时可以加

    13510

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券