Redis事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
Redis事务的主要作用就是串联多个命令防止别的命令插队。
从输入Multi命令开始,输入的命令都会依次进入命令队列中,但不会执行,直到输入Exec后,Redis会将之前的命令队列中的命令依次执行。
组队的过程中可以通过discard来放弃组队。
案例1:组队成功,提交成功(执行成功)
案例2:组队阶段报错,提交失败(执行失败)
案例3:组队成功,提交有成功有失败情况
组队中某个命令出现了报告错误,执行时整个的所有队列都会被取消。
对应上面案例2
如果执行阶段某个命令报出了错误,则只有报错的命令不会被执行,而其他的命令都会执行,不会回滚。
对应上面案例3