扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
本文小编为大家详细介绍“数据库的乐观锁如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“数据库的乐观锁如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
成都创新互联公司是一家专业从事成都网站设计、成都网站制作、网页设计的品牌网络公司。如今是成都地区具影响力的网站设计公司,作为专业的成都网站建设公司,成都创新互联公司依托强大的技术实力、以及多年的网站运营经验,为您提供专业的成都网站建设、营销型网站建设及网站设计开发服务!
线程锁分类有很多种,乐观锁是其中之一。乐观锁的实现是通过数据版本(Version)记录机制实现的,是乐观锁最常用的实现方式。什么是数据版本?即为数据添加版本标识,一般是通过在数据库中添加数字“版本”字段来实现的桌子。读取数据时,将version字段的值一起读取,每次更新数据时version值加一。当我们提交更新时,我们判断数据库表中对应记录的当前版本信息与第一次检索到的版本值进行比较。如果数据库表的当前版本号等于第一次检索到的版本值,则更新它。否则视为过期数据。
任务
共有三个字段,分别是id、value、version
(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语句,这样更新任务表时不会发生冲突。
/** * 基于乐观锁的更新操作 * @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); 返回标记; }
读到这里,这篇“数据库的乐观锁如何实现”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注创新互联行业资讯频道。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流