mybatis-plus乐观锁实现方式详解
悲观锁、乐观锁简介:
悲观锁:同步操作。即用户A在操作某条数据时,为其上锁,限制其他用户操作,用户A操作完成提交事务后其他用户方可操作此数据。
乐观锁:使用版本控制字段。更新某条数据时,先判断此数据的version是否符合条件,若符合则更新反之更新失败。
mybatis-plus乐观锁实现方式
1.向数据库中添加版本控制字段version
ALTER TABLE `user` ADD COLUMN `version` INT
2.实体类中对应此字段添加@Version注解
特别说明:
特别说明:
- 支持的数据类型只有 int,Integer,long,Long,Date,Timestamp,LocalDateTime
- 整数类型下 newVersion = oldVersion + 1
- newVersion 会回写到 entity 中
- 仅支持 updateById(id) 与 update(entity, wrapper) 方法
- 在 update(entity, wrapper) 方法下, wrapper 不能复用!!!
3.写个配置类,注册乐观锁插件
@Configuration @MapperScan("com.atguigu.mybatis_plus.mapper") public class MybatisPlusConfig { /** * 乐观锁插件 */ @Bean public OptimisticLockerInterceptor optimisticLockerInterceptor() { return new OptimisticLockerInterceptor(); } }
到此这篇关于mybatis-plus乐观锁实现方式的文章就介绍到这了,更多相关mybatis-plus乐观锁内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
相关推荐
-
Mybatis plus的自动填充与乐观锁的实例详解(springboot)
自动填充 项目中经常会遇到一些数据,每次都使用相同的方式填充,如插入时间.更新时间.Mybatis-plus的自动填充功能可以帮助我们快速实现. 1.表中加入create_time,update_time字段 2.实体类注解填充字段 @TableField(fill= FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date updateTime; /**
-
MP(MyBatis-Plus)实现乐观锁更新功能的示例代码
实现步骤 step1:添加乐观锁拦截器 MP的其他拦截器功能可以参考官网 @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); return int
-
mybatis plus乐观锁及实现详解
目录 乐观锁 一.什么是乐观锁 二.MP来实现乐观锁 1.在实体类里增加对于的字段,并且加上自动填充(你也可以每次手动填充) 2. 配置插件 3.测试乐观锁 乐观锁 乐观锁”这个词以前我也没听过.上次在测试需求的时候,查询数据库发现有一个version字段,于是请教开发这个字干嘛使 人家回复我:乐观锁,解决并发更新用的.当时大家都忙,咱也不敢多问. 今天就来折腾一下“乐观锁”. 一.什么是乐观锁 乐观锁其实用一句话来形容其作用就是:当要更新一条记录的时候,希望这条记录没有被别人更新,从而实现线程
-
mybatis-plus乐观锁实现方式详解
悲观锁.乐观锁简介: 悲观锁:同步操作.即用户A在操作某条数据时,为其上锁,限制其他用户操作,用户A操作完成提交事务后其他用户方可操作此数据. 乐观锁:使用版本控制字段.更新某条数据时,先判断此数据的version是否符合条件,若符合则更新反之更新失败. mybatis-plus乐观锁实现方式 1.向数据库中添加版本控制字段version ALTER TABLE `user` ADD COLUMN `version` INT 2.实体类中对应此字段添加@Version注解 特别说明: 特别说明:
-
Mybatis的几种传参方式详解
前言 前几天恰好面试一个应届生,问了一个很简单的问题:你了解过Mybatis中有几种传参方式吗? 没想到其他问题回答的很好,唯独这个问题一知半解,勉强回答了其中两种方式. 于是这篇文章就来说一说Mybatis传参的几种常见方式,给正在面试或者准备面试的朋友巩固一下. 单个参数 单个参数的传参比较简单,可以是任意形式的,比如#{a}.#{b}或者#{param1},但是为了开发规范,尽量使用和入参时一样. Mapper如下: UserInfo selectByUserId(String userI
-
Mybatis实现Mapper动态代理方式详解
一.实现原理 Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同上边Dao接口实现类方法. Mapper接口开发需要遵循以下规范: 1.Mapper.xml文件中的namespace与mapper接口的类路径相同. 2. Mapper接口方法名和Mapper.xml中定义的每个statement的id相同 3.Mapper接口方法的输入参数类型和mapper.xml中定义的每个sql 的para
-
spring、mybatis 配置方式详解(常用两种方式)
在之前的文章中总结了三种方式,但是有两种是注解sql的,这种方式比较混乱所以大家不怎么使用,下面总结一下常用的两种总结方式: 一. 动态代理实现 不用写dao的实现类 这种方式比较简单,不用实现dao层,只需要定义接口就可以了,这里只是为了记录配置文件所以程序写的很简单: 1.整体结构图: 2.三个配置文件以及一个映射文件 (1).程序入口以及前端控制器配置 web.xml <?xml version="1.0" encoding="UTF-8"?> &
-
MyBatis源码剖析之Mapper代理方式详解
目录 源码剖析-getmapper() 源码剖析-invoke() 具体代码如下: //前三步都相同 InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream); SqlSession sqlSess
-
Mybatis velocity脚本的使用教程详解(推荐)
可能很多童鞋都还不是很清楚在mybatis可以使用各种脚本语言来定义Mapper文件里面的动态SQL:目前mybatis支持的脚本语言有XML(默认的):Velocity和Freemarker三种.使用不同的脚本语言来完成Mapper文件的编写,第一是使用自己熟悉的脚本语言,第二是能够定义更多丰富的自定义指令来简化Mapper的开发,关于MyBatis支持脚本的原理分析,自定义脚本指令后面再写文章分析,本文先介绍mybatis中velocity脚本的使用方式. mybatis-velocity项
-
单利模式及python实现方式详解
单例模式 单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保 某一个类只有一个实例存在 .当希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场. 比如,某个服务器程序的配置信息存放在一个文件中,客户端通过一个 AppConfig 的类来读取配置文件的信息.如果在程序运行期间,有很多地方都需要使用配置文件的内容,也就是说,很多地方都需要创建 AppConfig 对象的实例,这就导致系统中存在多个 AppConfig 的实例对象,而这样会严重
-
mapper接口注入两种方式详解
这篇文章主要介绍了mapper接口注入两种方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.使用模板方式: <!--使用模板类实现mybatis --> <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate"> <constructor-arg name="sqlSessionFacto
随机推荐
- PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
- ASP 三层架构 Error处理类
- Vue.js路由组件vue-router使用方法详解
- Python网站验证码识别
- php链表用法实例分析
- jsp 编程之@WebServlet详解
- Linux 分区初始化为物理卷,把物理卷加入卷组的方法
- 自编jQuery插件实现模拟alert和confirm
- 解决FastCGI 进程超过了配置的活动超时时限的问题
- Spring mvc整合mybatis(crud+分页插件)操作mysql
- 大数据时代的数据库选择:SQL还是NoSQL?
- jquery 学习之二 属性(html()与html(val))
- vue-router+vuex addRoutes实现路由动态加载及菜单动态加载
- 快速解决Android平台移植ffmpeg的一些问题
- 页里面 CDATA的作用说明
- 微信小程序实现动态改变view标签宽度和高度的方法【附demo源码下载】
- PHP迭代器接口Iterator用法分析
- Python开发最牛逼的IDE——pycharm
- VirtualBox创建的Debian虚拟机与Windows宿主共享文件
- MySQL线程处于Opening tables的问题解决方法