redis在事务中可以执行DISCARD 执行后 MULTI到DISCARD之间的命令无效,这就和rollback实现的效果没区别了
那为什么说不支持回滚呢
为什么说redis的事务不支持回滚?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 柏油 2022-09-21 18:10关注
redis 事务通过 multi 开启,本质是给服务端发送一条指令说明这是事务请求,后续服务端接收的指令就放在队列中,直到 exec 指令提交,才开始真正的执行所有指令。
当你提交 discard 相当于废弃当前事务,服务端接收后直接清空当前所有信息(状态、队列中的指令 ...),相当于事务没有提交就放弃了,没有提交哪有回滚一说?
当你 discard 提交后再看看服务端返回:
127.0.0.1:6379> multi OK 127.0.0.1:6379> set key 1 QUEUED 127.0.0.1:6379> discard OK 127.0.0.1:6379> exec (error) ERR EXEC without MULTI
告诉你当前已经没有事务了。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 对于这个问题的解释说明
- ¥200 询问:python实现大地主题正反算的程序设计,有偿
- ¥15 smptlib使用465端口发送邮件失败
- ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
- ¥15 对于squad数据集的基于bert模型的微调
- ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
- ¥20 steam下载游戏占用内存
- ¥15 CST保存项目时失败
- ¥20 java在应用程序里获取不到扬声器设备
- ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。