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 echarts绘制图表
- ¥15 根据企业名称 对照两个文件 样本筛选/匹配
- ¥15 Linux环境下CA证书更新问题
- ¥15 sqlserver语句提取结果以外数据
- ¥60 微信小程序如何上传QQ聊天文件
- ¥300 开发的系统遭到无良商家的破解,请问如何防止再次发生,并追回损失
- ¥15 java代码写在记事本上后在cmd上运行时无报错但又没生成文件
- ¥15 关于#python#的问题:在跑ldsc数据整理的时候一直抱这种错误,要么--out识别不了参数,要么--merge-alleles识别不了参数(操作系统-linux)
- ¥15 PPOCRLabel
- ¥15 混合键合键合机对准标识