返回顶部
首页 > 资讯 > 数据库 >数据库锁之乐观锁
  • 409
分享到

数据库锁之乐观锁

2024-04-02 19:04:59 409人浏览 薄情痞子
摘要

一、乐观锁的介绍   乐观锁是相对悲观锁而言,也是为了避免数据库幻读、业务处理时间过长等原因引起数据处理错误的一种机制,但乐观锁不会刻意使用数据库本身的锁机制,而是依据数据本身来保证数据

一、乐观锁的介绍

   乐观是相对悲观锁而言,也是为了避免数据库幻读、业务处理时间过长等原因引起数据处理错误的一种机制,但乐观锁不会刻意使用数据库本身的锁机制,而是依据数据本身来保证数据的正确性。

  乐观锁的机制:对每条数据库加上版本号或时间撮,在每次对数据进行操作(尤其是修改操作)时,总会带上版本号获取数据同时更改后修改版本号。


二、乐观锁的代码示例

  2.1 创建一张表 

    create table em_oplock

    (

      id VARCHAR(100) not null,

      value VARCHAR(100),

      version int(10),

      PRIMARY key(id)

    ) ENGINE=INNODB DEFAULT CHARSET=utf8;

 2.2 插入一条数据

    INSERT into em_oplock values('1','1',1);

 2.3 修改数据

    update em_oplock set value='2',version=version+1 where id = 1 and version = 1;


三、乐观锁的业务使用示例

    事务1


数据库锁之乐观锁


   事务2

      

数据库锁之乐观锁


    说明:

   当两个用户同时操作ID为1的数据或一个用户未处理完另一个用户也对此数据操作时,两个用户获取数据做了一系列的业务处理后都认为自己的数据判断是正确的,于是都对同一条数据进行修改提交。如果我们不做版本控制的话,后处理的用户将覆盖前面用户的数据。如果我们加上版本控制的话,当用户1处理成功后,用户2将一条数据都不会处理。


四、悲观锁的业务使用示例


   事务1:成功锁定数据

      

数据库锁之乐观锁

    事务2:等待锁的释放

   

数据库锁之乐观锁


   事务1:操作锁定数据并提交,同时释放锁定数据

     

数据库锁之乐观锁


    事务2:获取数据锁(最新数据)


数据库锁之乐观锁

说明:

  为了对数据处理的正确性,在操作数据前先对数据进行锁定(for update)。利用数据库本身的排它锁机制,保证了数据只能一个用户一个用户的处理。


五、乐观锁与悲观锁的比较

  

  5.1 乐观锁需要增加额外的字段来记录版本号,增加了数据库设计复杂度。(乐观锁的劣势)

  5.2 乐观锁需要每个修改的地方同时更新版本号,增加了开发的成本。(乐观锁的劣势)

  5.3 当并发量大或业务时间处理比较长时,就会造成数据库锁长时间等待,限制并发量和快速消耗数据库资源。(悲观锁的劣势)

  5.4 悲观锁操作时,需要对数据库的锁机制有一定程度的理解才行。否则,容易造成表锁或死锁。(悲观锁的劣势)



六、乐观锁与悲观锁的选择

  

  不论是悲观锁还是乐观锁,都是为实际业务服务的,都是为了保证数据的正确性。选择乐观锁还是悲观锁需要根据具体的业务场景、数据库设计、开发成本等因素进行权衡。如果此业务涉及的面比较多、开发人员比较多等,建议用悲观锁。如果此业务比较单一或数据库操作的地方比较少、并发量要求很高等情况下,建议用乐观锁。 

  如果我们把业务设计得更合理一点,数据为设计更好一点,也许不需要这么麻烦!












您可能感兴趣的文档:

--结束END--

本文标题: 数据库锁之乐观锁

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

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

猜你喜欢
  • 数据库锁之乐观锁
    一、乐观锁的介绍   乐观锁是相对悲观锁而言,也是为了避免数据库幻读、业务处理时间过长等原因引起数据处理错误的一种机制,但乐观锁不会刻意使用数据库本身的锁机制,而是依据数据本身来保证数据...
    99+
    2024-04-02
  • Java多线程之悲观锁与乐观锁
    目录1. 悲观锁存在的问题2. 通过CAS实现乐观锁3. 不可重入的自旋锁4. 可重入的自旋锁总结问题: 1、乐观锁和悲观锁的理解及如何实现,有哪些实现方式? 2、什么是乐观锁和悲观...
    99+
    2024-04-02
  • mysql 乐观锁和悲观锁
    悲观锁介绍(百科): 悲观锁,正如其名,它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中, 将数据处于锁定状态。悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层...
    99+
    2023-09-02
    mysql 数据库 java
  • 乐观锁以及乐观锁的实现
    乐观锁介绍: 乐观锁( Optimistic Locking ) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让返回用户错误的信息,让用户决定...
    99+
    2016-09-19
    乐观锁以及乐观锁的实现
  • 数据库的乐观锁如何实现
    本文小编为大家详细介绍“数据库的乐观锁如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“数据库的乐观锁如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。线程锁分类有很多...
    99+
    2024-04-02
  • 悲观锁,乐观锁的概念
    悲观锁:顾名思义,就是很悲观,它指的是对数据被外界(包括本系统当前的其他事务,以及来自其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于锁定状态。悲观锁实现,往往依...
    99+
    2024-04-02
  • MySQL中的悲观锁与乐观锁
    在关系型数据库中,悲观锁与乐观锁是解决资源并发场景的解决方案,接下来将详细讲解🔎一下这两个并发解决方案的实际使用及优缺点。 首先定义一下数据库,做一个最简单的库存表,如下设计: CREATE TA...
    99+
    2022-05-15
    MySQL 悲观锁 MySQL 乐观锁
  • 悲观锁和乐观锁是什么
    悲观锁和乐观锁是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。乐观锁( Optimistic Locking )乐观锁( ...
    99+
    2024-04-02
  • 什么是悲观锁和乐观锁
    什么是悲观锁和乐观锁?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 悲观锁(Pessimistic Lock), 顾...
    99+
    2024-04-02
  • MySQL乐观锁和悲观锁介绍
    乐观锁 乐观锁不是数据库自带的,需要我们自己去实现。乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去...
    99+
    2024-04-02
  • mybatis使用乐观锁和悲观锁
    悲观锁和乐观锁的概念: 悲观锁:就是独占锁,不管读写都上锁了。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。Java中synchronized和ReentrantLock等独占锁就是悲...
    99+
    2023-08-30
    mysql
  • Spring Boot2+JPA之悲观锁和乐观锁实战教程
    目录前言悲观锁与并发利用SQL的for update解决并发问题利用JPA的@Lock行锁注解解决并发问题如果是@NameQuery,则可以乐观锁与并发利用version字...
    99+
    2024-04-02
  • 什么是乐观锁、悲观锁和MVCC
    本篇内容主要讲解“什么是乐观锁、悲观锁和MVCC”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是乐观锁、悲观锁和MVCC”吧!在数据库的实际使用过程中,我们...
    99+
    2024-04-02
  • redis乐观锁与悲观锁的实战
    目录概念乐观锁悲观锁乐观锁示例悲观锁示例总结提升概念 Redis是一个内存中的键值存储系统,支持多种数据结构,如字符串、哈希、列表等。Redis提供了两种锁机制,即乐观锁和悲观锁。 乐观锁 乐观锁是一种乐观的并发控制策略...
    99+
    2023-04-13
    redis 乐观锁 悲观锁 redis 乐观锁 redis 悲观锁
  • MySQL乐观锁和悲观锁具体实现
    目录前言锁分类表结构悲观锁乐观锁适用场景总结前言 对于mysql中的乐观锁和悲观锁,可能很多的开发者还不是很熟悉,并不知道其中具体是如何实现的。本文就针对这个问题做一个实际案例演示,让你彻底明白这两种锁的区别。 锁分类 ...
    99+
    2024-04-02
  • MySQL中乐观锁和悲观锁是什么
    这篇文章给大家分享的是有关MySQL中乐观锁和悲观锁是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。数据库管理系统中并发控制的任务是确保在多个事务同时存取数据库中同一数据不破...
    99+
    2024-04-02
  • MySQL中乐观锁和悲观锁的区别
    这篇文章将为大家详细讲解有关MySQL中乐观锁和悲观锁的区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。悲观锁在关系数据库管理系统中,悲观并发控制(悲观锁...
    99+
    2024-04-02
  • 详解Java中的悲观锁与乐观锁
    目录一、悲观锁二、乐观锁三、CAS四、AtomicXXX五、CAS中的ABA问题六、ABA问题解决方案七、使用CAS会引起的问题八、Synchronized锁优化九、偏向锁十、轻量级...
    99+
    2024-04-02
  • MySQL乐观锁和悲观锁如何实现
    这篇文章主要介绍了MySQL乐观锁和悲观锁如何实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MySQL乐观锁和悲观锁如何实现文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
  • java中乐观锁与悲观锁的概念
    这篇文章主要介绍“java中乐观锁与悲观锁的概念”,在日常操作中,相信很多人在java中乐观锁与悲观锁的概念问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java中乐观锁与悲观锁的概念”的疑惑有所帮助!接下来...
    99+
    2023-06-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作