经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MyBatis » 查看文章
MyBatis-Plus乐观锁插件的用法小结
来源:jb51  时间:2022/8/23 11:26:51  对本文有异议

什么是乐观锁:

就是我们每一次操作数据后,我们就会更改他的版本号,当另外的线程若想要对该数据进行操作,检查版本号是否与自己获得的版本号一致,如果不一致,那么我们就会取消该操作。

简介

说明

本文介绍Mybatis-Plus的乐观锁插件的用法。

官网网址

乐观锁插件 | MyBatis-Plus

配置乐观锁插件

  1. @Configuration
  2. public class MyBatisPlusConfig {
  3. @Bean
  4. public MybatisPlusInterceptor mybatisPlusInterceptor() {
  5. MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
  6. mybatisPlusInterceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
  7. return mybatisPlusInterceptor;
  8. }
  9. }

Entity

版本号的字段上加注解

  1. @Version
  2. private Integer version;

说明:

  • 支持的数据类型只有:int,Integer,long,Long,Date,Timestamp,LocalDateTime
  • 整数类型下 newVersion = oldVersion + 1
  • newVersion 会回写到 entity 中
  • 仅支持 updateById(id) 与 update(entity, wrapper) 方法
  • 在 update(entity, wrapper) 方法下, wrapper 不能复用!!!

测试

MP会把设置进去的版本号当作更新条件,并且版本号+1更新进去。

  1. @Test
  2. public void update(){
  3. User user = userMapper.getById(1L);
  4. user.setEmail("Test1111@email.com");
  5. user.setUpdateTime(LocalDateTime.now());
  6. int update = userMapper.updateById(user);
  7. System.out.println(update);
  8. }
  1. DEBUG==> Preparing: UPDATE sys_user SET email=?, update_time=?, version=? WHERE id=? AND version=?
  2. DEBUG==> Parameters: Test1111@email.com(String), 2019-09-19T16:00:38.149(LocalDateTime), 2(Integer), 1(Long), 1(Integer)
  3. DEBUG<== Updates: 1

到此这篇关于MyBatis-Plus乐观锁插件的用法的文章就介绍到这了,更多相关MyBatis-Plus乐观锁插件内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号