热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

数据库锁机制通俗易懂介绍

目录一、为什么需要使用锁,什么是锁二、锁有哪些1、按数据操作的粒度来分表锁行锁页锁2、按数据操作的类型来分读锁(共享锁、S锁)写锁(排他锁或互斥锁、X锁)3、按使用方式来分乐观锁悲

目录
  • 一、为什么需要使用锁,什么是锁
  • 二、锁有哪些
    • 1、按数据操作的粒度来分
      • 表锁
      • 行锁
      • 页锁
    • 2、按数据操作的类型来分
      • 读锁(共享锁、S锁)
      • 写锁(排他锁或互斥锁、X锁)
    • 3、按使用方式来分
      • 乐观锁
      • 悲观锁
    • 表锁下的读写操作时:
      • 表锁的特点:
      • 读锁(read lock)
      • 写锁(write lock)
      • 如何上锁:
    • 行锁下的读写操作时:
      • 行锁的特点
      • 读锁(read lock)
      • 写锁(write lock)
      • 意向共享锁(IS)
      • 意向排它锁(IX)
      • 如何上锁
    • 页锁
  • 三、乐观锁和悲观锁
  • 四、行锁的实现算法
    • 1、Record Lock 锁
    • 2、Gap Lock 锁
    • 3、Next-key Lock 锁
  • 五、死锁


一、为什么需要使用锁,什么是锁

官方的介绍:

锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统计算资源(CPU、RAM、I\O等)的争抢,数据也是一种供多用户共享的资源。如何保证数据并发访问的一致性,有效性,是所有数据库必须要解决的问题。锁冲突也是影响数据库并发访问性能的一个重要因素,因此锁对数据库尤其重要。

对于上面的几句话介绍什么是锁,相信看了后抽象难以理解,下面我举一个生活中通俗易懂的例子,说明什么是锁,以及为什么需要使用锁。

【工人搬转的例子】



  • 一个工人搬砖时

假如现在一个老板有堆砖头一共有30块左右,需要找人帮忙。随后就找到了A工人搬转。


202202271803

  • 多个工人搬砖时

然后,老板又觉得一个人搬砖太慢了,所以就多叫两个工人,B工人、C工人过来帮忙。


202202271811

  • 多个工人搬砖时,会带来的问题

1、会发现工人们之间,说的砖头数量不一样

假如三个ABC工人同一时间去搬砖的。大家一开始只知道那堆砖头有30块而已。

比如工人去搬5块砖头,心里想搬完5块,还有25块。

接着B工人去搬6块砖头。心里想搬完5块,还有24块。

接着C工人去搬1块砖头。心里想搬完1块,还有29块。

最后老板过来问大家,现在还多少砖头。A工人:25块、B工人:24块、C工人:29块。

一听,这数量不对呀,各说各的,肯定有问题这样。其实真实还有30-12=18块而已,但是工人之间都不知道,大家搬了多少块砖头。



  • 解决多个工人搬砖时,带来的问题

为了解决上述的问题,老板就想了个办法。

A搬砖时,B、C工人不能去搬砖,只有A工人搬完离开,B、C工人才可以去搬砖头。

并且告诉B工人现在还有多少块砖头,B工人和C工人同理。


202202271848

好了,举完这个

推荐阅读
  • 本文深入探讨了MySQL中的高级特性,包括索引机制、锁的使用及管理、以及如何利用慢查询日志优化性能。适合有一定MySQL基础的读者进一步提升技能。 ... [详细]
  • Java高级工程师学习路径及面试准备指南
    本文基于一位朋友的PDF面试经验整理,涵盖了Java高级工程师所需掌握的核心知识点,包括数据结构与算法、计算机网络、数据库、操作系统等多个方面,并提供了详细的参考资料和学习建议。 ... [详细]
  • 对于非计算机专业背景的开发者而言,如何快速掌握.NET基础知识以应对技术面试是一个挑战。本文将提供一系列实用建议,帮助读者在短时间内提高.NET基础水平。 ... [详细]
  • 春季职场跃迁指南:如何高效利用金三银四跳槽季
    随着每年的‘金三银四’跳槽高峰期的到来,许多职场人士都开始考虑是否应该寻找新的职业机会。本文将探讨如何制定有效的职业规划、撰写吸引人的简历以及掌握面试技巧,助您在这关键时期成功实现职场跃迁。 ... [详细]
  • 本文详细介绍了如何使用Linux下的mysqlshow命令来查询MySQL数据库的相关信息,包括数据库、表以及字段的详情。通过本文的学习,读者可以掌握mysqlshow命令的基本语法及其常用选项。 ... [详细]
  • selenium通过JS语法操作页面元素
    做过web测试的小伙伴们都知道,web元素现在很多是JS写的,那么既然是JS写的,可以通过JS语言去操作页面,来帮助我们操作一些selenium不能覆盖的功能。问题来了我们能否通过 ... [详细]
  • 本文详细探讨了 Android Service 组件中 onStartCommand 方法的四种不同返回值及其应用场景。Service 可以在后台执行长时间的操作,无需提供用户界面,支持通过启动和绑定两种方式创建。 ... [详细]
  • Excel技巧:单元格中显示公式而非结果的解决方法
    本文探讨了在Excel中如何通过简单的方法解决单元格显示公式而非计算结果的问题,包括使用快捷键和调整单元格格式两种方法。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文介绍了用户界面(User Interface, UI)的基本概念,以及在iOS应用程序中UIView及其子类的重要性和使用方式。文章详细探讨了UIView如何作为用户交互的核心组件,以及它与其他UI控件和业务逻辑的关系。 ... [详细]
  • 本文探讨了线性表中元素的删除方法,包括顺序表和链表的不同实现策略,以及这些策略在实际应用中的性能分析。 ... [详细]
  • 实现Win10与Linux服务器的SSH无密码登录
    本文介绍了如何在Windows 10环境下使用Git工具,通过配置SSH密钥对,实现与Linux服务器的无密码登录。主要步骤包括生成本地公钥、上传至服务器以及配置服务器端的信任关系。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • Zabbix自定义监控与邮件告警配置实践
    本文详细介绍了如何在Zabbix中添加自定义监控项目,配置邮件告警功能,并解决测试告警时遇到的邮件不发送问题。 ... [详细]
  • TCP协议中的可靠传输机制分析
    本文深入探讨了TCP协议如何通过滑动窗口和超时重传来确保数据传输的可靠性,同时介绍了流量控制和拥塞控制的基本原理及其在实际网络通信中的应用。 ... [详细]
author-avatar
霸道Q丫头
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有