zoukankan      html  css  js  c++  java
  • Spring Data Mongodb 乐观锁

    Spring Data 针对mongodb提供了乐观锁实现:

    The @Version annotation provides syntax similar to that of JPA in the context of MongoDB and makes sure updates are only applied to documents with a matching version. Therefore, the actual value of the version property is added to the update query in such a way that the update does not have any effect if another operation altered the document in the meantime. In that case, an OptimisticLockingFailureException is thrown. The following example shows these features:
    

    提供@Version注解,用来标识版本,保存、删除等操作会验证version,不一致会抛出OptimisticLockingFailureException

    来看一个例子:

    @Document
    class Person {
    
      @Id String id;
      String firstname;
      String lastname;
      @Version Long version;
    }
    
    Person daenerys = template.insert(new Person("Daenerys"));                            (1)
    
    Person tmp = template.findOne(query(where("id").is(daenerys.getId())), Person.class); (2)
    
    daenerys.setLastname("Targaryen");
    template.save(daenerys);                                                              (3)
    
    template.save(tmp); // throws OptimisticLockingFailureException                       (4)
    
    1. 最初插入一个person daenerysversion0

    2. 加载刚插入的数据,tmpversion还是0

    3. 更新version = 0daenerys,更新lastname,save后version变为1

    4. 现在来更新,会抛出OptimisticLockingFailureException, 提示操作失败。

    注意:

    Important Optimistic Locking requires to set the WriteConcern to ACKNOWLEDGED. Otherwise OptimisticLockingFailureException can be silently swallowed.
    Note As of Version 2.2 MongoOperations also includes the @Version property when removing an entity from the database. To remove a Document without version check use MongoOperations#remove(Query,…​) instead of MongoOperations#remove(Object).
    Note As of Version 2.2 repositories check for the outcome of acknowledged deletes when removing versioned entities. An OptimisticLockingFailureException is raised if a versioned entity cannot be deleted through CrudRepository.delete(Object). In such case, the version was changed or the object was deleted in the meantime. Use CrudRepository.deleteById(ID) to bypass optimistic locking functionality and delete objects regardless of their version.

    作者:Jadepeng
    出处:jqpeng的技术记事本--http://www.cnblogs.com/xiaoqi
    您的支持是对博主最大的鼓励,感谢您的认真阅读。
    本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    前端总结数据结构与算法基础
    Linux 常用命令
    mariadb下载二进制包源码包地址(使用清华)
    centos7添加永久静态路由
    登录普通用户会报错-bash: ulimit: open files: cannot modify limit: Operation not permitted
    编写二进制安装mariadb10.2的ansible-playbook剧本
    su
    URL后面加不加“/”有区别吗?
    RocketMQ在面试中那些常见问题及答案+汇总
    通过实现网站访问计数器带你理解 轻量级锁CAS原理,还学不会算我输!!!
  • 原文地址:https://www.cnblogs.com/xiaoqi/p/spring-data-optimistic-lock.html
Copyright © 2011-2022 走看看