专注Java教育14年 全国咨询/投诉热线:400-8080-105
动力节点LOGO图
始于2009,口口相传的Java黄埔军校
首页 hot资讯 乐观锁的实现

乐观锁的实现

更新时间:2022-09-27 10:02:33 来源:动力节点 浏览886次

线程锁分类有很多种,乐观锁是其中之一。乐观锁的实现是通过数据版本(Version)记录机制实现的,是乐观锁最常用的实现方式。什么是数据版本?即为数据添加版本标识,一般是通过在数据库中添加数字“版本”字段来实现的桌子。读取数据时,将version字段的值一起读取,每次更新数据时version值加一。当我们提交更新时,我们判断数据库表中对应记录的当前版本信息与第一次检索到的版本值进行比较。如果数据库表的当前版本号等于第一次检索到的版本值,则更新它。否则视为过期数据。

1.数据库表设计

任务

共有三个字段,分别是id、value、version

2.实现

(1)首先读取task表中的数据(实际上这个表只有一条记录),得到version的值为versionValue

(2)每次更新任务表中的value字段,为了防止冲突,需要这样做

更新任务集 value = newValue,version = versionValue + 1

其中 version = versionValue;

只有当这条语句执行时,才表示value字段的值更新成功

例如,如果有两个节点 A 和 B 更新任务表中的 value 字段值,大约同时,节点 A 和节点 B 从任务表中读取的版本值是 2,那么节点 A 和节点B 正在更新 value 字段值时,更新任务集 value = newValue, version = 3 where version = 2;,其实只有 1 个节点执行 SQL 语句成功,假设 A 节点执行成功,那么 version 字段此时任务表的值为3,然后B节点操作update task set value = newValue, version = 3 where version = 2; 不执行这条SQL语句,这样更新任务表时不会发生冲突。

3.项目中的用例

     /**
     	 * 基于乐观锁的更新操作
     	 * @param editFinance 编辑的账户对象
     	 * @param queryLockNo 上一次查询的乐观锁版本号
     	 * @return    
     	 */
     @覆盖
     公共 int  updateForLockNo (BzFinanceEntity editFinance, int queryLockNo)  {
     		editFinance.setLockNo(queryLockNo +
     1 ); 
     //修改乐观锁版本
     		BzFinanceEntityExample 示例 =
     新BzFinanceEntityExample();
     		BzFinanceEntityExample.Criteria 标准 = example.createCriteria();
     		criteria.andIdFinanceEqualTo(editFinance.getIdFinance());
     		criteria.andLockNoEqualTo(queryLockNo);
     //基于乐观锁,修改查询版本的数据	
     //根据Example条件更新不为null的实体BzFinanceEntity的属性值	
     int mark = 
      this .baseEntityDao.updateByExampleSelective(editFinance, example);		
     返回标记;
     	}  

以上就是关于“乐观锁的实现”的介绍,在本站多线程教程中还有更丰富的知识等着大家去学习,这是掌握多线程线程锁种类的必学内容,为我们后面学习多线程的更多内容打下坚实的基础。

提交申请后,顾问老师会电话与您沟通安排学习

免费课程推荐 >>
技术文档推荐 >>