返回顶部
首页 > 资讯 > 数据库 >Mysql的锁(S锁和X锁的区别)
  • 987
分享到

Mysql的锁(S锁和X锁的区别)

2024-04-02 19:04:59 987人浏览 泡泡鱼
摘要

共享锁和排它锁 Mysql的锁系统:shared lock 和 exclusive lock (共享锁和排它锁,也叫读锁和写锁,即read lock和write lock) 读锁是共享的,或者说是相互不

共享锁和排它锁

Mysql系统:shared lock 和 exclusive lock (共享锁和排它锁,也叫读锁和写锁,即read lock和write lock)

读锁是共享的,或者说是相互不阻塞的
写锁是排他的,一个写锁会阻塞其他的写锁和读锁
在实际的数据库系统中,每时每刻都发生锁定,当某个用户在修改某部分数据1时,mysql会通过1锁定阻止其他用户对统一数据的读取。

共享锁【S锁】

又称读锁,若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其他事务只能再对A加S锁,而不能加X锁,直到T释放A上的S锁。

这保证了其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改。

排他锁【X锁】

又称写锁。若事务T对数据对象A加上X锁,事务T可以读A也可以修改A,其他事务不能再对A加任何锁,直到T释放A上的锁。

这保证了其他事务在T释放A上的锁之前不能再读取和修改A。

排他锁用法:for update,比如,select name from table where id=1 for update;

锁的粒度和锁的策略

Mysql有三种锁的级别:页级、表级、行级。

MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。

MySQL这3种锁的特性可大致归纳如下:


  • 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。

  • 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。

  • 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

您可能感兴趣的文档:

--结束END--

本文标题: Mysql的锁(S锁和X锁的区别)

本文链接: https://lsjlt.com/news/37067.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mysql的锁(S锁和X锁的区别)
    共享锁和排它锁 Mysql的锁系统:shared lock 和 exclusive lock (共享锁和排它锁,也叫读锁和写锁,即read lock和write lock) 读锁是共享的,或者说是相互不...
    99+
    2024-04-02
  • 数据库的S锁和X锁,两段锁协议
    基本的封锁类型有两种:排它锁(X锁)和共享锁(S锁).所谓X锁,是事务T对数据A加上X锁时,只允许事务T读取和修改数据A,...所谓S锁,是事务T对数据A加上S锁时,其他事务只能再对数据A加S锁,而不能加...
    99+
    2024-04-02
  • mysql中的排它锁x和共享锁s的介绍
    这篇文章主要介绍“mysql中的排它锁x和共享锁s的介绍”,在日常操作中,相信很多人在mysql中的排它锁x和共享锁s的介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”my...
    99+
    2024-04-02
  • MySQL中乐观锁和悲观锁的区别
    这篇文章将为大家详细讲解有关MySQL中乐观锁和悲观锁的区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。悲观锁在关系数据库管理系统中,悲观并发控制(悲观锁...
    99+
    2024-04-02
  • 通过唯一索引S锁与X锁来了解MySQL死锁套路
    在初学者从源码理解MySQL死锁问题中介绍了使用调试 MySQL  源码的方式来查看死锁的过程,这篇文章来讲讲一个常见的案例。 这次我们讲一段唯一索引 S 锁与 X 锁的爱恨情仇 我们来看一个简化...
    99+
    2024-04-02
  • mysql表锁和行锁有哪些区别
    小编给大家分享一下mysql表锁和行锁有哪些区别,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧! Mysql有很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁;这...
    99+
    2024-04-02
  • mysql表锁和行锁区别是什么
    小编给大家分享一下mysql表锁和行锁区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、表锁特点:偏向MyISAM存储...
    99+
    2024-04-02
  • MySQL 行锁和表锁的含义及区别详解
    一、前言 对于行锁和表锁的含义区别,在面试中应该是高频出现的,我们应该对MySQL中的锁有一个系统的认识,更详细的需要自行查阅资料,本篇为概括性的总结回答。 MySQL常用引擎有MyISAM和InnoDB,而Inn...
    99+
    2022-05-17
    MySQL 行锁 MySQL 表锁 MySQL 行锁和表锁
  • MySQL间隙锁和临键锁的区别有哪些
    MySQL中的间隙锁(Gap Lock)和临键锁(Next-Key Lock)是用于并发控制的锁机制,用于处理多个事务同时操作同一数...
    99+
    2023-10-21
    MySQL
  • ​​​​​​​Java公平锁和非公平锁的区别
    目录正文应用场景公平和非公平锁代码演示执行流程分析公平锁执行流程非公平锁执行流程优缺点分析总结前言: 从公平的角度来说,Java 中的锁总共可分为两类:公平锁和非公平锁。但公平锁和非...
    99+
    2024-04-02
  • mysql乐观锁和悲观锁有什么区别
    本篇内容主要讲解“mysql乐观锁和悲观锁有什么区别”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql乐观锁和悲观锁有什么区别”吧! ...
    99+
    2024-04-02
  • mysql的共享锁与排他锁的区别和使用方法
    mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流。共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数...
    99+
    2024-04-02
  • mysql数据库中行级锁、表级锁和页级锁的区别是什么
    这篇文章主要介绍了mysql数据库中行级锁、表级锁和页级锁的区别是什么,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。按粒度可以分为:1、行级锁,MySQL中锁定粒度最细的一种锁,表示只针...
    99+
    2024-04-02
  • mysql中乐观锁和悲观锁有什么区别
    mysql中乐观锁和悲观锁的区别有:1.概念不同;2.使用场景不同;3.实现方式不同;4.特点不同;mysql中乐观锁和悲观锁的区别有以下几点概念不同mysql中乐观锁是对加锁持有一种乐观的态度,可以先进行业务操作,不到最后一步不进行加锁,...
    99+
    2024-04-02
  • 分析SIX锁和锁分区导致的死锁
    什么是SIX锁?官方文档锁模式中说到:意向排他共享 (SIX):保护针对层次结构中某些(而并非所有)低层资源请求或获取的共享锁以及针对某些(而并非所有)低层资源请求或获取的意向排他锁。 顶级资源允许使用并发...
    99+
    2024-04-02
  • MySQL的表级锁,行级锁,排它锁和共享锁
    目录前言一、表级锁&行级锁二、排它锁&共享锁1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上三、串行化隔离级别测试前言 如果我们和面试官聊到事务的问题,怎么回答呢? 先说下事务是什么...
    99+
    2022-07-14
    MySQL表级锁 MySQL行级锁 MySQL排它锁 MySQL共享锁
  • MySQL中的锁(表锁、行锁)
    锁是计算机协调多个进程或纯线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有效性是所在有数据库必须解决的一个问题,锁冲突也是影响数...
    99+
    2023-09-02
    java 算法 数据库
  • MySQL和Oracle行锁区别及用法
    下文主要给大家带来MySQL和Oracle行锁区别及用法,希望这些内容能够带给大家实际用处,这也是我编辑MySQL和Oracle行锁区别及用法这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。Inno...
    99+
    2024-04-02
  • MySQL的锁机制之全局锁和表锁的实现
    前言 对mysql锁的总结学习,本文将围绕,加锁的概念,加锁的应用场景和优化,以及不加锁会导致的问题这些方向进行总结学习。mysql的全局锁和表锁是本文的重点 一、全局锁 全局锁的介绍以及使用 全局锁就是对整个数据库实例...
    99+
    2023-01-15
    MySQL全局锁和表锁 MySQL全局锁 MySQL表锁
  • MySQL中行锁、页锁和表锁的实际应用
    下面一起来了解下MySQL中行锁、页锁和表锁的实际应用,相信大家看完肯定会受益匪浅,文字在精不在多,希望MySQL中行锁、页锁和表锁的实际应用这篇短内容是你想要的。 MySQL中按照锁的粒度可以细...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作