Re@R_502_6422@事务
Re@R_502_6422@事务是一组命令的集合,也是Re@R_502_6422@的最小执行单位之一。一个事务的所有命令,要么都执行,要么都不执行。Re@R_502_6422@能保证事务执行期间不会有其他命令插入。
相关命令
命令 | 格式 | 说明 |
@R_502_6422@CARD | @R_502_6422@CARD | 取消事务 |
EXEC | EXEC | 执行事务中的命令 |
MULTI | MULTI | 标记一个事务的开始 |
UNWATCH | UNWATCH | 取消对key的监视 |
WATCH | WATCH key [key ...] | 监视一个或多个key |
执行MULTI后,在EXEC或@R_502_6422@CARD之前发送的所有命令都会被Re@R_502_6422@按顺序缓存起来,并返回QUEUED。执行EXEC后,Re@R_502_6422@取出缓存的命令开始执行,并返回每一条命令的返回值。
使用WATCH监控的key如果发生了变化,事务将被打断。在EXEC或@R_502_6422@CARD执行后,WATCH监控自动失效,否则使用UNWATCH取消监控。
注意:
①执行MULTI后不能再执行WATCH,否则返回错误“WATCH inside MULTI is not allowed”;
②如果命令有语法错误Re@R_502_6422@会报错,但是运行时出现的错误会被Re@R_502_6422@忽略不影响后面的执行,需要自己确保不出现运行时错误;
使用方法
1、事务正常执行
192.168.1.100:6379> multi
OK
192.168.1.100:6379> set testkey 1
QUEUED
192.168.1.100:6379> incr testkey
QUEUED
192.168.1.100:6379> get testkey
QUEUED
192.168.1.100:6379> exec
1) OK
2) (integer) 2
3) "2"
2、WATCH监控的key变化,事务被打断
192.168.1.100:6379> watch testkey
OK
192.168.1.100:6379> multi
OK
192.168.1.100:6379> set testkey 1
QUEUED
# 此时另一个客户端执行 set testkey 2 改变了testkey的值
192.168.1.100:6379> exec
(nil)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。