redisTemplate开启事务支持

new SessionCallback() 接口 , 重写 execute方法 保证 在同一个会话中执行所有给定的操作

灰常的 easy , 上代码 !

redisTemplate.execute(new SessionCallback<Object>() {
            @Override
            public Object execute(RedisOperations operations) throws DataAccessException {
                operations.multi(); // 标记事务块的开始
                operations.opsForValue().set("name", "duguotao");
                operations.opsForValue().set("gender", "male");
                operations.opsForValue().set("age", "22");
                return operations.exec(); // 执行以 {multi()} 开始的事务中的所有排队命令。
            }
        });

推荐阅读

Redis分布式下的redis锁

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在这段代码中,我们可以看到一个名为CounterUtil的Java类,其中包含了使用redisTemplate进行redis事务的方法。 在这个方法中,首先通过ApplicationContextHolder.getBean方法获取了redisTemplate实例,并设置了redisTemplate事务支持。然后,通过watch方法监听了一个指定的key,当该key被其他客户端改变时,会中断当前操作。接着,获取了该key对应的value,并将其转换为int类型的count。然后,通过multi方法开始事务,调用opsForValue方法设置新的count值,并使用exec方法执行事务。如果在提交事务时发现key被改变,会报异常。反复执行该操作,直到事务成功执行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [RedisTemplate实现Redis事务](https://blog.csdn.net/bin929/article/details/118705619)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [深入理解Spring Redis的使用 (四)、RedisTemplate执行Redis脚本](https://blog.csdn.net/weixin_35340730/article/details/114535377)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值