热门标签 | 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

好了,举完这个

推荐阅读
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 探讨如何通过编程技术实现100个并发连接,解决线程创建顺序问题,并提供高效的并发测试方案。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
  • 本文详细介绍了MySQL InnoDB存储引擎中的间隙锁概念及其作用,探讨了它在解决幻读问题方面的关键角色,并解析了间隙锁与其他操作之间的冲突关系。同时,文章还讨论了next-key-lock的构成及应用,以及在不同场景下的优化策略。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 本文探讨如何设计一个安全的加密和验证算法,确保生成的密码具有高随机性和低重复率,并提供相应的验证机制。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • MongoDB集群配置:副本集与分片详解
    本文详细介绍了如何在MongoDB中配置副本集(Replica Sets)和分片(Sharding),并提供了具体的步骤和命令,帮助读者理解并实现高可用性和水平扩展的MongoDB集群。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本文详细介绍了 MySQL 的查询处理流程,包括从客户端连接到服务器、查询缓存检查、语句解析、查询优化及执行等步骤。同时,深入探讨了 MySQL 中的乐观锁机制及其在并发控制中的应用。 ... [详细]
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社区 版权所有